diff --git a/.github/sync.yml b/.github/sync.yml index ed11331b..cdac887d 100755 --- a/.github/sync.yml +++ b/.github/sync.yml @@ -3,20 +3,22 @@ group: - files: - - source: .github/workflows/render-bookdown.yml - dest: .github/workflows/render-bookdown.yml - - source: .github/workflows/render-preview.yml - dest: .github/workflows/render-preview.yml - - source: .github/workflows/render-leanpub.yml - dest: .github/workflows/render-leanpub.yml - - source: .github/workflows/docker-build-test.yml - dest: .github/workflows/docker-build-test.yml + - source: config_automation.yml + dest: config_automation.yml + - source: .github/workflows/ + dest: .github/workflows/ + deleteOrphaned: true + - source: scripts/ + dest: scripts/ + deleteOrphaned: true + - source: .github/workflows/pull-request.yml + dest: .github/workflows/pull-request.yml + - source: .github/workflows/render-all.yml + dest: .github/workflows/render-all.yml + - source: .github/workflows/docker-build.yml + dest: .github/workflows/docker-build.yml - source: .github/workflows/transfer-rendered-files.yml dest: .github/workflows/transfer-rendered-files.yml - - source: .github/workflows/style-and-sp-check.yml - dest: .github/workflows/style-and-sp-check.yml - - source: .github/workflows/url-checker.yml - dest: .github/workflows/url-checker.yml - source: .github/workflows/release-notes.yml dest: .github/workflows/release-notes.yml - source: .github/workflows/delete-preview.yml @@ -29,8 +31,6 @@ group: dest: scripts/make_screenshots.R - source: scripts/spell-check.R dest: scripts/spell-check.R - - source: scripts/get_spell_errors.R - dest: scripts/get_spell_errors.R - source: scripts/git_repo_check.R dest: scripts/git_repo_check.R - source: code_of_conduct.md @@ -62,10 +62,8 @@ group: ### This is a custom group for this repo which doesn't want syncing on all the files ### - files: - - source: .github/workflows/style-and-sp-check.yml - dest: .github/workflows/style-and-sp-check.yml - - source: .github/workflows/url-checker.yml - dest: .github/workflows/url-checker.yml + - source: .github/workflows/pull-request.yml + dest: .github/workflows/pull-request.yml - source: scripts/spell-check.R dest: scripts/spell-check.R repos: | diff --git a/.github/workflows/check-quizzes.yml b/.github/workflows/check-quizzes.yml deleted file mode 100644 index 189ae4d8..00000000 --- a/.github/workflows/check-quizzes.yml +++ /dev/null @@ -1,116 +0,0 @@ -# Candace Savonen Jan 2022 - -name: Check Leanpub Quizzes - -#---TRIGGER-START---# -on: - workflow_dispatch: - pull_request: - branches: [ main, staging ] - paths: - - 'quizzes/*' -#---TRIGGER-END----# - -jobs: - check-quizzes: - runs-on: ubuntu-latest - container: - image: jhudsl/course_template - - steps: - - name: Checkout files - uses: actions/checkout@v2 - with: - fetch-depth: 0 - - - name: Configure git - run: | - git config --local user.email "itcrtrainingnetwork@gmail.com" - git config --local user.name "jhudsl-robot" - - branch_name='check-${{ github.event.pull_request.number }}' - exists=$(git ls-remote https://${{ secrets.GH_PAT }}@github.com/$GITHUB_REPOSITORY $branch_name | wc -l | xargs) - if [[ $exists == 0 ]];then - echo branch doesnt exist - git checkout -b $branch_name - git push --set-upstream origin $branch_name - else - echo branch does exist - git fetch --all - git checkout $branch_name - git merge -s recursive --strategy-option=theirs origin/${{ github.head_ref }} - fi - shell: bash - - - name: Run quiz check - id: quiz_check_run - run: | - Rscript -e "ottr::check_quizzes(quiz_dir = 'quizzes', write_report = TRUE, verbose = TRUE)" - results=0 - if -f "question_error_report.tsv"; then - results=$(wc -l < question_error_report.tsv >/dev/null) - fi - echo ::set-output name=quiz_chk_results::$results - - - name: Commit quiz check errors - run: | - branch_name='check-${{ github.event.pull_request.number }}' - git diff --name-only origin/main -- question_error_report.tsv >/dev/null && changes=true || changes=false - echo $changes - if $changes == true; then - git diff --name-only origin/$branch_name question_error_report.tsv >/dev/null && changes=true || changes=false - echo $changes - if $changes == true; then - git add --force question_error_report.tsv - git diff-index --quiet HEAD || git commit -m 'Add question error report file' - git pull --set-upstream origin $branch_name --allow-unrelated-histories - git push origin $branch_name - fi - fi - - - name: Build components of the quiz check comment - id: build-components - env: - GH_PAT: ${{ secrets.GH_PAT }} - run: | - branch_name='check-${{ github.event.pull_request.number }}' - quiz_error_url=https://raw.githubusercontent.com/${GITHUB_REPOSITORY}/$branch_name/question_error_report.tsv - echo ::set-output name=time::$(date +'%Y-%m-%d') - echo ::set-output name=commit_id::$GITHUB_SHA - echo ::set-output name=quiz_error_url::$quiz_error_url - - # Handle the commenting - - name: Find Comment - uses: peter-evans/find-comment@v1 - id: fc - with: - issue-number: ${{ github.event.pull_request.number }} - comment-author: 'github-actions[bot]' - body-includes: quiz errors - - - name: Quiz errors! - if: ${{ steps.quiz_check_run.outputs.quiz_chk_results >= 2 }} - uses: peter-evans/create-or-update-comment@v1 - with: - comment-id: ${{ steps.fc.outputs.comment-id }} - issue-number: ${{ github.event.pull_request.number }} - body: | - :warning: There are quiz errors that need to be addressed. [Read this guide for more info](https://github.com/jhudsl/OTTR_Template/wiki/Publishing-on-Leanpub#setting-up-quizzes). - [Download the errors here.](${{ steps.build-components.outputs.quiz_error_url }}) - _Comment updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ - edit-mode: replace - - - name: Check quiz check results - fail if too many errors - if: ${{ steps.quiz_check_run.outputs.quiz_chk_results >= 2 }} - run: exit 1 - - - name: No quiz errors - if: ${{ steps.quiz_check_run.outputs.quiz_chk_results < 2 }} - uses: peter-evans/create-or-update-comment@v1 - with: - comment-id: ${{ steps.fc.outputs.comment-id }} - issue-number: ${{ github.event.pull_request.number }} - body: | - No quiz errors detected! :tada: - _Comment updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ - edit-mode: replace diff --git a/.github/workflows/delete-preview.yml b/.github/workflows/delete-preview.yml index 81b68b93..0359e51c 100644 --- a/.github/workflows/delete-preview.yml +++ b/.github/workflows/delete-preview.yml @@ -2,11 +2,9 @@ name: Delete Preview -#---TRIGGER-START---# on: pull_request: types: [closed] -#---TRIGGER-END---# jobs: delete-preview: @@ -19,8 +17,7 @@ jobs: shell: bash # Delete the branch! - - name: Delete branch - uses: dawidd6/action-delete-branch@v3 - with: - github_token: ${{ secrets.GH_PAT }} - branches: preview-${{ github.event.pull_request.number }} + - name: Delete branch locally and remotely + run: | + git branch -d preview-${{ github.event.pull_request.number }} || echo "No branch to delete" + git push origin --delete preview-${{ github.event.pull_request.number }} || echo "No branch to delete" diff --git a/.github/workflows/docker-build-test.yml b/.github/workflows/docker-build.yml similarity index 68% rename from .github/workflows/docker-build-test.yml rename to .github/workflows/docker-build.yml index 33f81cac..d1971c0b 100644 --- a/.github/workflows/docker-build-test.yml +++ b/.github/workflows/docker-build.yml @@ -1,26 +1,18 @@ # Candace Savonen Apr 2021 -name: Build of Docker +name: Build Docker - -#---TRIGGER-START---# on: - release: - types: - - created - pull_request: - branches: [ main, staging ] - paths: [ docker/Dockerfile, docker/github_package_list.tsv ] workflow_dispatch: inputs: dockerhubpush: description: 'Push to Dockerhub?' required: true default: 'false' -#---TRIGGER-END----# jobs: build-docker: + name: Build Docker image runs-on: ubuntu-latest steps: @@ -33,18 +25,15 @@ jobs: git config --local user.name "jhudsl-robot" - name: Don't re-test if this is a sync branch - if: ${{ github.head_ref == 'repo-sync/OTTR_Template/default' }} run: | echo This was tested on OTTR_Template no need to re-run # Set up Docker build - name: Set up Docker Buildx - if: ${{ github.head_ref != 'repo-sync/OTTR_Template/default' }} uses: docker/setup-buildx-action@v1 # Setup layer cache - name: Cache Docker layers - if: ${{ github.head_ref != 'repo-sync/OTTR_Template/default' }} uses: actions/cache@v2 with: path: /tmp/.buildx-cache @@ -58,12 +47,10 @@ jobs: uses: docker/setup-buildx-action@v1 - name: Get token - if: ${{ github.head_ref != 'repo-sync/OTTR_Template/default' }} run: echo ${{ secrets.GH_PAT }} > docker/git_token.txt # Build docker image - name: Build Docker image - if: ${{ github.head_ref != 'repo-sync/OTTR_Template/default' }} uses: docker/build-push-action@v2 with: push: false @@ -86,14 +73,6 @@ jobs: run: docker push jhudsl/course_template - name: Get the version - if: ${{ github.head_ref != 'repo-sync/OTTR_Template/default' }} id: get_version run: | echo ::set-output name=version::$(echo $GITHUB_REF | cut -d / -f 3) - - # Push the Docker image if it is a release - - name: Push Docker image if release - if: ${{ github.event_name == 'release' }} - run: | - docker tag jhudsl/course_template:latest jhudsl/course_template:${{ steps.get_version.outputs.version }} - docker push jhudsl/course_template:${{ steps.get_version.outputs.version }} diff --git a/.github/workflows/pull_request.yml b/.github/workflows/pull_request.yml new file mode 100644 index 00000000..93688b3e --- /dev/null +++ b/.github/workflows/pull_request.yml @@ -0,0 +1,452 @@ +# Candace Savonen Dec 2021 + +name: Pull Request + +on: + pull_request: + branches: [ main, staging ] + +jobs: + + yaml-check: + name: Load user automation choices + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v2 + + # Use the yaml-env-action action. + - name: Load environment from YAML + uses: doughepi/yaml-env-action@v1.0.0 + with: + files: config_automation.yml # Pass a space-separated list of configuration files. Rightmost files take precedence. + + - name: Verify Dockerfiles changed? + uses: tj-actions/verify-changed-files@v8.8 + id: verify-changed-files + with: + files: | + docker/Dockerfile + docker/github_package_list.tsv + + outputs: + toggle_quiz_check: "${{ env.CHECK_QUIZZES }}" + toggle_spell_check: "${{ env.STYLE_AND_SP_CHECK }}" + toggle_url_check: "${{ env.URL_CHECKER }}" + toggle_render_preview: "${{ env.RENDER_PREVIEW }}" + toggle_docker_build: "${{ env.DOCKER_BUILD }}" + dockerfiles_changed: steps.verify-changed-files.outputs.files_changed + + style-n-check: + name: Check style and spelling + needs: yaml-check + runs-on: ubuntu-latest + if: ${{needs.yaml-check.outputs.toggle_spell_check == 'yes'}} + container: + image: jhudsl/course_template + + steps: + - name: Checkout files + uses: actions/checkout@v2 + with: + fetch-depth: 0 + + - name: Configure git + run: | + git config --local user.email "itcrtrainingnetwork@gmail.com" + git config --local user.name "jhudsl-robot" + + branch_name='preview-${{ github.event.pull_request.number }}' + exists=$(git ls-remote https://${{ secrets.GH_PAT }}@github.com/$GITHUB_REPOSITORY $branch_name | wc -l | xargs) + if [[ $exists == 0 ]];then + echo branch doesnt exist + git checkout -b $branch_name + git push --set-upstream origin $branch_name + else + echo branch does exist + git fetch --all + git checkout $branch_name + git merge -s recursive --strategy-option=theirs origin/${{ github.head_ref }} + fi + shell: bash + + - name: Run spell check + id: spell_check_run + run: | + results=$(Rscript "scripts/spell-check.R") + echo "::set-output name=sp_chk_results::$results" + cat resources/spell_check_results.tsv + + - name: Archive spelling errors + uses: actions/upload-artifact@v2 + with: + name: spell-check-results + path: resources/spell_check_results.tsv + + - name: Commit spell check errors + run: | + branch_name='preview-${{ github.event.pull_request.number }}' + git add --force resources/spell_check_results.tsv + git commit -m 'Add spell check file' || echo "No changes to commit" + git pull --set-upstream origin $branch_name --allow-unrelated-histories + git push --force origin $branch_name || echo "No changes to commit" + + - name: Build components of the spell check comment + id: build-components + env: + GH_PAT: ${{ secrets.GH_PAT }} + run: | + branch_name='preview-${{ github.event.pull_request.number }}' + sp_error_url=https://raw.githubusercontent.com/${GITHUB_REPOSITORY}/$branch_name/resources/spell_check_results.tsv + echo ::set-output name=time::$(date +'%Y-%m-%d') + echo ::set-output name=commit_id::$GITHUB_SHA + echo ::set-output name=sp_error_url::$sp_error_url + + # Handle the commenting + - name: Find Comment + uses: peter-evans/find-comment@v1 + id: fc + with: + issue-number: ${{ github.event.pull_request.number }} + comment-author: 'github-actions[bot]' + body-includes: spelling errors + + - name: Spelling errors! + if: ${{ steps.spell_check_run.outputs.sp_chk_results >= 3 }} + uses: peter-evans/create-or-update-comment@v1 + with: + comment-id: ${{ steps.fc.outputs.comment-id }} + issue-number: ${{ github.event.pull_request.number }} + body: | + :warning: There are spelling errors that need to be addressed. [Read this guide for more info](https://github.com/jhudsl/OTTR_Template/wiki/Spell-check). + [Download the errors here.](${{ steps.build-components.outputs.sp_error_url }}) + _Comment updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ + edit-mode: replace + + - name: Check spell check results - fail if too many errors + if: ${{ steps.spell_check_run.outputs.sp_chk_results >= 3 }} + run: exit 1 + + - name: No spelling errors + if: ${{ steps.spell_check_run.outputs.sp_chk_results < 3 }} + uses: peter-evans/create-or-update-comment@v1 + with: + comment-id: ${{ steps.fc.outputs.comment-id }} + issue-number: ${{ github.event.pull_request.number }} + body: | + No spelling errors! :tada: + _Comment updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ + edit-mode: replace + + - name: Run styler + run: Rscript -e "styler::style_file(list.files(pattern = 'Rmd$', recursive = TRUE, full.names = TRUE));warnings()" + + - name: Commit styled files + run: | + git add \*.Rmd + git add resources/spell_check_results.tsv + git commit -m 'Style Rmds' || echo "No changes to commit" + git push origin || echo "No changes to commit" + + url-check: + name: Check URLs + needs: yaml-check + runs-on: ubuntu-latest + if: ${{needs.yaml-check.outputs.toggle_url_check == 'yes'}} + + steps: + - name: checkout repo + uses: actions/checkout@v2 + + - name: Login as jhudsl-robot + run: | + git config --local user.email "itcrtrainingnetwork@gmail.com" + git config --local user.name "jhudsl-robot" + + - name: URLs-checker + uses: urlstechie/urlchecker-action@master + with: + # Delete the cloned repository after running URLchecked (default is false) + cleanup: true + + # A comma-separated list of file types to cover in the URL checks + file_types: .Rmd,.md + + # Choose whether to include file with no URLs in the prints. + print_all: false + + # A comma separated links to exclude during URL checks + exclude_urls: https://jhudatascience.org/{Course_Name}} + + # choose if the force pass or not + force_pass : true + + check-quizzes: + name: Check Leanpub quizzes + needs: yaml-check + runs-on: ubuntu-latest + container: + image: jhudsl/course_template + if: ${{needs.yaml-check.outputs.toggle_quiz_check == 'yes'}} + steps: + - name: Checkout files + uses: actions/checkout@v2 + with: + fetch-depth: 0 + + - name: Configure git + run: | + git config --local user.email "itcrtrainingnetwork@gmail.com" + git config --local user.name "jhudsl-robot" + + branch_name='preview-${{ github.event.pull_request.number }}' + exists=$(git ls-remote https://${{ secrets.GH_PAT }}@github.com/$GITHUB_REPOSITORY $branch_name | wc -l | xargs) + if [[ $exists == 0 ]];then + echo branch doesnt exist + git checkout -b $branch_name + git push --set-upstream origin $branch_name + else + echo branch does exist + git fetch --all + git checkout $branch_name + git merge -s recursive --strategy-option=theirs origin/${{ github.head_ref }} + fi + shell: bash + + - name: Run quiz check + id: quiz_check_run + run: | + Rscript -e "ottr::check_quizzes(quiz_dir = 'quizzes', write_report = TRUE, verbose = TRUE)" + results=0 + if -f "question_error_report.tsv"; then + results=$(wc -l < question_error_report.tsv >/dev/null) + fi + echo ::set-output name=quiz_chk_results::$results + + - name: Commit quiz check errors + run: | + branch_name='preview-${{ github.event.pull_request.number }}' + git diff --name-only origin/main -- question_error_report.tsv >/dev/null && changes=true || changes=false + echo $changes + if $changes == true; then + git diff --name-only origin/$branch_name question_error_report.tsv >/dev/null && changes=true || changes=false + echo $changes + if $changes == true; then + git add --force question_error_report.tsv + git diff-index --quiet HEAD || git commit -m 'Add question error report file' + git pull --set-upstream origin $branch_name --allow-unrelated-histories + git push origin $branch_name + fi + fi + + - name: Build components of the quiz check comment + id: build-components + env: + GH_PAT: ${{ secrets.GH_PAT }} + run: | + branch_name='preview-${{ github.event.pull_request.number }}' + quiz_error_url=https://raw.githubusercontent.com/${GITHUB_REPOSITORY}/$branch_name/question_error_report.tsv + echo ::set-output name=time::$(date +'%Y-%m-%d') + echo ::set-output name=commit_id::$GITHUB_SHA + echo ::set-output name=quiz_error_url::$quiz_error_url + + # Handle the commenting + - name: Find Comment + uses: peter-evans/find-comment@v1 + id: fc + with: + issue-number: ${{ github.event.pull_request.number }} + comment-author: 'github-actions[bot]' + body-includes: quiz errors + + - name: Quiz errors! + if: ${{ steps.quiz_check_run.outputs.quiz_chk_results >= 2 }} + uses: peter-evans/create-or-update-comment@v1 + with: + comment-id: ${{ steps.fc.outputs.comment-id }} + issue-number: ${{ github.event.pull_request.number }} + body: | + :warning: There are quiz errors that need to be addressed. [Read this guide for more info](https://github.com/jhudsl/OTTR_Template/wiki/Publishing-on-Leanpub#setting-up-quizzes). + [Download the errors here.](${{ steps.build-components.outputs.quiz_error_url }}) + _Comment updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ + edit-mode: replace + + - name: Check quiz check results - fail if too many errors + if: ${{ steps.quiz_check_run.outputs.quiz_chk_results >= 2 }} + run: exit 1 + + - name: No quiz errors + if: ${{ steps.quiz_check_run.outputs.quiz_chk_results < 2 }} + uses: peter-evans/create-or-update-comment@v1 + with: + comment-id: ${{ steps.fc.outputs.comment-id }} + issue-number: ${{ github.event.pull_request.number }} + body: | + No quiz errors detected! :tada: + _Comment updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ + edit-mode: replace + + render-preview: + name: Render preview + needs: yaml-check + runs-on: ubuntu-latest + container: + image: jhudsl/course_template + if: ${{needs.yaml-check.outputs.toggle_render_preview == 'yes'}} + steps: + - name: Checkout files + uses: actions/checkout@v2 + with: + fetch-depth: 0 + + # Set up git checkout + - name: Set up git checkout + run: | + git config --local user.email "itcrtrainingnetwork@gmail.com" + git config --local user.name "jhudsl-robot" + + branch_name='preview-${{ github.event.pull_request.number }}' + exists=$(git ls-remote https://${{ secrets.GH_PAT }}@github.com/$GITHUB_REPOSITORY $branch_name | wc -l | xargs) + if [[ $exists == 0 ]];then + echo branch doesnt exist + git checkout -b $branch_name + git push --set-upstream origin $branch_name + else + echo branch does exist + git fetch --all + git checkout $branch_name + git merge -s recursive --strategy-option=theirs origin/${{ github.head_ref }} + fi + + rm -r docs/* + shell: bash + + # Run bookdown rendering + - name: Run bookdown render + id: bookdown + run: Rscript -e "bookdown::render_book('index.Rmd', output_format = 'all')" + + # Run Coursera version + - name: Run Coursera version of render + id: coursera + run: Rscript -e "ottr::render_coursera()" + + # This checks on the steps before it and makes sure that they completed. + # If the renders didn't complete we don't want to commit the file changes + - name: Check on render steps + if: steps.bookdown.outcome != 'success' || steps.coursera.outcome != 'success' + run: | + echo Bookdown status ${{steps.bookdown.outcome}} + echo Coursera status ${{steps.coursera.outcome}} + exit 1 + + # Commit the rendered bookdown files + - name: Commit rendered bookdown files to preview branch + id: commit + run: | + branch_name='preview-${{ github.event.pull_request.number }}' + git add . --force + git commit -m 'Render bookdown preview' || echo "No changes to commit" + git pull --set-upstream origin $branch_name --allow-unrelated-histories + git push --force || echo "No changes to commit" + shell: bash + + - name: Find Comment + uses: peter-evans/find-comment@v1 + id: fc + with: + issue-number: ${{ github.event.pull_request.number }} + comment-author: 'github-actions[bot]' + body-includes: latest commit + + - name: Build components of the comment + id: build-components + run: | + course_name=$(head -n 1 _bookdown.yml | cut -d'"' -f 2| tr " " "-") + bookdown_link=$(echo "https://htmlpreview.github.io/?https://raw.githubusercontent.com/$GITHUB_REPOSITORY/preview-${{ github.event.pull_request.number }}/docs/index.html") + coursera_link=$(echo "https://htmlpreview.github.io/?https://raw.githubusercontent.com/$GITHUB_REPOSITORY/preview-${{ github.event.pull_request.number }}/docs/coursera/index.html") + docx_link=$(echo "https://github.com/$GITHUB_REPOSITORY/raw/preview-${{ github.event.pull_request.number }}/docs/$course_name.docx") + echo ::set-output name=bookdown_link::$bookdown_link + echo ::set-output name=coursera_link::$coursera_link + echo ::set-output name=docx_link::$docx_link + echo ::set-output name=time::$(date +'%Y-%m-%d') + echo ::set-output name=commit_id::$GITHUB_SHA + echo ${{steps.commit.outputs.changes}} + + - name: Create or update comment + if: steps.commit.outputs.changes == 'changes' + uses: peter-evans/create-or-update-comment@v1 + with: + comment-id: ${{ steps.fc.outputs.comment-id }} + issue-number: ${{ github.event.pull_request.number }} + body: | + Re-rendered previews from the latest commit: + - See [preview of Bookdown here](${{ steps.build-components.outputs.bookdown_link }}) + - See [preview of Coursera version here](${{ steps.build-components.outputs.coursera_link }}) + - Download the [preview of .docx file](${{ steps.build-components.outputs.docx_link }}) + + _Updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ + edit-mode: replace + + - name: No comment if no changes + if: steps.commit.outputs.changes == 'no_changes' + uses: peter-evans/create-or-update-comment@v1 + with: + comment-id: ${{ steps.fc.outputs.comment-id }} + issue-number: ${{ github.event.pull_request.number }} + body: | + The latest commit did not produce rendering changes. + + _Updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ + edit-mode: replace + + build-docker: + name: Build Docker image + needs: yaml-check + runs-on: ubuntu-latest + if: ${{needs.yaml-check.outputs.toggle_docker_build == 'yes' && needs.yaml-check.outputs.dockerfiles_changed == 'true' && github.head_ref != 'repo-sync/OTTR_Template/default'}} + + steps: + - name: checkout repo + uses: actions/checkout@v2 + + - name: Verify Dockerfiles changed? + uses: tj-actions/verify-changed-files@v8.8 + id: verify-changed-files + with: + files: | + docker/Dockerfile + docker/github_package_list.tsv + + - name: Login as jhudsl-robot + run: | + git config --local user.email "itcrtrainingnetwork@gmail.com" + git config --local user.name "jhudsl-robot" + + # Set up Docker build + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v1 + + # Setup layer cache + - name: Cache Docker layers + uses: actions/cache@v2 + with: + path: /tmp/.buildx-cache + key: ${{ runner.os }}-buildx-${{ github.sha }} + restore-keys: | + ${{ runner.os }}-buildx- + + - name: Set up Docker Build + uses: docker/setup-buildx-action@v1 + + - name: Get token + run: echo ${{ secrets.GH_PAT }} > docker/git_token.txt + + - name: Build Docker image + uses: docker/build-push-action@v2 + with: + push: false + load: true + context: docker + file: docker/Dockerfile + tags: jhudsl/course_template diff --git a/.github/workflows/release-notes.yml b/.github/workflows/release-notes.yml index f4eb7d02..475b3a8d 100644 --- a/.github/workflows/release-notes.yml +++ b/.github/workflows/release-notes.yml @@ -2,12 +2,10 @@ name: Release note PR comment -#---TRIGGER-START---# on: pull_request: branches: [ main, staging ] types: [ opened ] -#---TRIGGER-END----# jobs: pr-comment: diff --git a/.github/workflows/render-all.yml b/.github/workflows/render-all.yml new file mode 100644 index 00000000..ad987698 --- /dev/null +++ b/.github/workflows/render-all.yml @@ -0,0 +1,168 @@ + +# Candace Savonen Apr 2021 + +name: Render all output courses + +on: + workflow_dispatch: + push: + branches: [ main, staging ] + paths: + - '**.Rmd' + - assets/* + +jobs: + + yaml-check: + name: Load user automation choices + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v2 + + # Use the yaml-env-action action. + - name: Load environment from YAML + uses: doughepi/yaml-env-action@v1.0.0 + with: + files: config_automation.yml # Pass a space-separated list of configuration files. Rightmost files take precedence. + outputs: + toggle_bookdown: "${{ env.RENDER_BOOKDOWN }}" + toggle_coursera: "${{ env.RENDER_COURSERA }}" + toggle_leanpub: "${{ env.RENDER_LEANPUB }}" + + render-bookdown: + name: Render bookdown + needs: yaml-check + runs-on: ubuntu-latest + container: + image: jhudsl/course_template + if: ${{needs.yaml-check.outputs.toggle_bookdown == 'yes'}} + + steps: + - name: checkout + uses: actions/checkout@v2 + with: + fetch-depth: 0 + token: ${{ secrets.GH_PAT }} + + - name: Login as jhudsl-robot + run: | + git config --local user.email "itcrtrainingnetwork@gmail.com" + git config --local user.name "jhudsl-robot" + + # We want a fresh run of the renders each time + - name: Delete old docs/* + run: rm -r docs/* + + # Run bookdown rendering + - name: Run bookdown render + id: bookdown + run: | + Rscript -e "bookdown::render_book('index.Rmd', output_format = 'all'); + file.copy(from = 'assets', to = 'docs/assets', overwrite = TRUE)" + + # This checks on the steps before it and makes sure that they completed. + # If the renders didn't complete we don't want to commit the file changes + - name: Check on render step + if: steps.bookdown.outcome != 'success' + run: | + echo Bookdown status ${{steps.bookdown.outcome}} + exit 1 + + # Commit the rendered bookdown files + - name: Commit rendered bookdown files + run: | + git config --local user.email "actions@github.com" + git config --local user.name "GitHub Actions" + git add --force docs/* + git commit -m 'Render bookdown' || echo "No changes to commit" + git push origin main || echo "No changes to push" + + render-coursera: + name: Render Coursera + needs: [yaml-check, render-bookdown] + runs-on: ubuntu-latest + container: + image: jhudsl/course_template + if: ${{needs.yaml-check.outputs.toggle_coursera == 'yes'}} + + steps: + - name: checkout + uses: actions/checkout@v2 + with: + fetch-depth: 0 + token: ${{ secrets.GH_PAT }} + + - name: Login as jhudsl-robot + run: | + git config --local user.email "itcrtrainingnetwork@gmail.com" + git config --local user.name "jhudsl-robot" + + # Run Coursera version + - name: Run Coursera version of render + id: coursera + run: Rscript -e "ottr::render_coursera(convert_quizzes = TRUE)" + + # This checks on the steps before it and makes sure that they completed. + # If the renders didn't complete we don't want to commit the file changes + - name: Check on render steps + if: steps.coursera.outcome != 'success' + run: | + echo Coursera status ${{steps.coursera.outcome}} + exit 1 + + # Commit the rendered bookdown files + - name: Commit rendered Coursera files + run: | + git config --local user.email "actions@github.com" + git config --local user.name "GitHub Actions" + git add --force docs/coursera/* + git commit -m 'Render Coursera' || echo "No changes to commit" + git push origin main || echo "No changes to push" + + render-leanpub: + name: Render Leanpub + needs: [yaml-check, render-coursera] + runs-on: ubuntu-latest + container: + image: jhudsl/ottr + if: ${{needs.yaml-check.outputs.toggle_leanpub == 'yes'}} + + steps: + - name: checkout + uses: actions/checkout@v2 + with: + fetch-depth: 0 + token: ${{ secrets.GH_PAT }} + + - name: Login as jhudsl-robot + run: | + git config --local user.email "itcrtrainingnetwork@gmail.com" + git config --local user.name "jhudsl-robot" + + # Create screenshots + - name: Run the screenshot creation + run: | + chapt_urls=$(Rscript --vanilla scripts/make_screenshots.R \ + --git_pat ${{ secrets.GH_PAT }} \ + --repo $GITHUB_REPOSITORY) + + # We want a fresh run of the renders each time + - name: Delete old manuscript/ + run: rm -rf manuscript/ + + # Run Leanpub rendering + - name: Run ottr::bookdown_to_embed_leanpub + run: | + Rscript -e "ottr::bookdown_to_embed_leanpub( \ + chapt_img_key = 'resources/chapt_screen_images/chapter_urls.tsv', \ + make_book_txt = TRUE)" + + # Commit the rendered leanpub files + - name: Commit rendered leanpub files + run: | + git config --local user.email "actions@github.com" + git config --local user.name "GitHub Actions" + git add --force manuscript/* + git commit -m 'Render Leanpub' || echo "No changes to commit" + git push --force origin main || echo "No changes to push" diff --git a/.github/workflows/render-bookdown.yml b/.github/workflows/render-bookdown.yml deleted file mode 100644 index 5c8253dc..00000000 --- a/.github/workflows/render-bookdown.yml +++ /dev/null @@ -1,60 +0,0 @@ - -# Candace Savonen Apr 2021 - -name: Render Bookdown - -#---TRIGGER-START---# -on: - workflow_dispatch: - push: - branches: [ main, staging ] - paths: - - '**.Rmd' - - assets/* -#---TRIGGER-END----# - -jobs: - render-bookdown: - runs-on: ubuntu-latest - container: - image: jhudsl/course_template - - steps: - - name: checkout - uses: actions/checkout@v2 - with: - fetch-depth: 0 - token: ${{ secrets.GH_PAT }} - - - name: Login as jhudsl-robot - run: | - git config --local user.email "itcrtrainingnetwork@gmail.com" - git config --local user.name "jhudsl-robot" - - # We want a fresh run of the renders each time - - name: Delete old docs/* - run: rm -r docs/* - - # Run bookdown rendering - - name: Run bookdown render - id: bookdown - run: | - Rscript -e "bookdown::render_book('index.Rmd', output_format = 'all'); - file.copy(from = 'assets', to = 'docs/assets', overwrite = TRUE)" - - # This checks on the steps before it and makes sure that they completed. - # If the renders didn't complete we don't want to commit the file changes - - name: Check on render step - if: steps.bookdown.outcome != 'success' - run: | - echo Bookdown status ${{steps.bookdown.outcome}} - exit 1 - - # Commit the rendered bookdown files - - name: Commit rendered bookdown files - run: | - git config --local user.email "actions@github.com" - git config --local user.name "GitHub Actions" - git add --force docs/* - git commit -m 'Render bookdown' || echo "No changes to commit" - git push origin main || echo "No changes to push" diff --git a/.github/workflows/render-coursera.yml b/.github/workflows/render-coursera.yml deleted file mode 100644 index cfc3a04a..00000000 --- a/.github/workflows/render-coursera.yml +++ /dev/null @@ -1,54 +0,0 @@ - -# Candace Savonen Apr 2021 - -name: Render Coursera - -#---TRIGGER-START---# -on: - workflow_dispatch: - workflow_run: - workflows: [ "Render Bookdown" ] - branches: [ main, staging ] - types: - - completed -#---TRIGGER-END----# - -jobs: - render-coursera: - runs-on: ubuntu-latest - container: - image: jhudsl/course_template - - steps: - - name: checkout - uses: actions/checkout@v2 - with: - fetch-depth: 0 - token: ${{ secrets.GH_PAT }} - - - name: Login as jhudsl-robot - run: | - git config --local user.email "itcrtrainingnetwork@gmail.com" - git config --local user.name "jhudsl-robot" - - # Run Coursera version - - name: Run Coursera version of render - id: coursera - run: Rscript -e "ottr::render_coursera(convert_quizzes = TRUE)" - - # This checks on the steps before it and makes sure that they completed. - # If the renders didn't complete we don't want to commit the file changes - - name: Check on render steps - if: steps.coursera.outcome != 'success' - run: | - echo Coursera status ${{steps.coursera.outcome}} - exit 1 - - # Commit the rendered bookdown files - - name: Commit rendered Coursera files - run: | - git config --local user.email "actions@github.com" - git config --local user.name "GitHub Actions" - git add --force docs/coursera/* - git commit -m 'Render Coursera' || echo "No changes to commit" - git push origin main || echo "No changes to push" diff --git a/.github/workflows/render-leanpub.yml b/.github/workflows/render-leanpub.yml deleted file mode 100644 index 61ff1e8d..00000000 --- a/.github/workflows/render-leanpub.yml +++ /dev/null @@ -1,59 +0,0 @@ - -# Jan 2022 Candace Savonen - -name: Render Leanpub - -#---TRIGGER-START---# -on: - workflow_dispatch: - workflow_run: - workflows: [ "Render Coursera" ] - branches: [ main, staging ] - types: - - completed -#---TRIGGER-END----# - -jobs: - render-leanpub: - runs-on: ubuntu-latest - container: - image: jhudsl/ottr - - steps: - - name: checkout - uses: actions/checkout@v2 - with: - fetch-depth: 0 - token: ${{ secrets.GH_PAT }} - - - name: Login as jhudsl-robot - run: | - git config --local user.email "itcrtrainingnetwork@gmail.com" - git config --local user.name "jhudsl-robot" - - # Create screenshots - - name: Run the screenshot creation - run: | - chapt_urls=$(Rscript --vanilla scripts/make_screenshots.R \ - --git_pat ${{ secrets.GH_PAT }} \ - --repo $GITHUB_REPOSITORY) - - # We want a fresh run of the renders each time - - name: Delete old manuscript/ - run: rm -rf manuscript/ - - # Run Leanpub rendering - - name: Run ottr::bookdown_to_embed_leanpub - run: | - Rscript -e "ottr::bookdown_to_embed_leanpub( \ - chapt_img_key = 'resources/chapt_screen_images/chapter_urls.tsv', \ - make_book_txt = TRUE)" - - # Commit the rendered leanpub files - - name: Commit rendered leanpub files - run: | - git config --local user.email "actions@github.com" - git config --local user.name "GitHub Actions" - git add --force manuscript/* - git commit -m 'Render Leanpub' || echo "No changes to commit" - git push --force origin main || echo "No changes to push" diff --git a/.github/workflows/render-preview.yml b/.github/workflows/render-preview.yml deleted file mode 100644 index 078a7978..00000000 --- a/.github/workflows/render-preview.yml +++ /dev/null @@ -1,124 +0,0 @@ -# Candace Savonen Apr 2021 - -name: Render Preview - -#---TRIGGER-START---# -on: - pull_request: - branches: [ main, staging ] -#---TRIGGER-END----# - -permissions: write-all - -jobs: - render-preview: - runs-on: ubuntu-latest - container: - image: jhudsl/course_template - - steps: - - name: Checkout files - uses: actions/checkout@v2 - with: - fetch-depth: 0 - - # Set up git checkout - - name: Set up git checkout - run: | - git config --local user.email "itcrtrainingnetwork@gmail.com" - git config --local user.name "jhudsl-robot" - - branch_name='preview-${{ github.event.pull_request.number }}' - exists=$(git ls-remote https://${{ secrets.GH_PAT }}@github.com/$GITHUB_REPOSITORY $branch_name | wc -l | xargs) - if [[ $exists == 0 ]];then - echo branch doesnt exist - git checkout -b $branch_name - git push --set-upstream origin $branch_name - else - echo branch does exist - git fetch --all - git checkout $branch_name - git merge -s recursive --strategy-option=theirs origin/${{ github.head_ref }} - fi - - rm -r docs/* - shell: bash - - # Run bookdown rendering - - name: Run bookdown render - id: bookdown - run: Rscript -e "bookdown::render_book('index.Rmd', output_format = 'all')" - - # Run Coursera version - - name: Run Coursera version of render - id: coursera - run: Rscript -e "ottr::render_coursera()" - - # This checks on the steps before it and makes sure that they completed. - # If the renders didn't complete we don't want to commit the file changes - - name: Check on render steps - if: steps.bookdown.outcome != 'success' || steps.coursera.outcome != 'success' - run: | - echo Bookdown status ${{steps.bookdown.outcome}} - echo Coursera status ${{steps.coursera.outcome}} - exit 1 - - # Commit the rendered bookdown files - - name: Commit rendered bookdown files to preview branch - id: commit - run: | - branch_name='preview-${{ github.event.pull_request.number }}' - git add . --force - git commit -m 'Render bookdown preview' || echo "No changes to commit" - git pull --set-upstream origin $branch_name --allow-unrelated-histories - git push --force || echo "No changes to commit" - shell: bash - - - name: Find Comment - uses: peter-evans/find-comment@v1 - id: fc - with: - issue-number: ${{ github.event.pull_request.number }} - comment-author: 'github-actions[bot]' - body-includes: latest commit - - - name: Build components of the comment - id: build-components - run: | - course_name=$(head -n 1 _bookdown.yml | cut -d'"' -f 2| tr " " "-") - bookdown_link=$(echo "https://htmlpreview.github.io/?https://raw.githubusercontent.com/$GITHUB_REPOSITORY/preview-${{ github.event.pull_request.number }}/docs/index.html") - coursera_link=$(echo "https://htmlpreview.github.io/?https://raw.githubusercontent.com/$GITHUB_REPOSITORY/preview-${{ github.event.pull_request.number }}/docs/coursera/index.html") - docx_link=$(echo "https://github.com/$GITHUB_REPOSITORY/raw/preview-${{ github.event.pull_request.number }}/docs/$course_name.docx") - echo ::set-output name=bookdown_link::$bookdown_link - echo ::set-output name=coursera_link::$coursera_link - echo ::set-output name=docx_link::$docx_link - echo ::set-output name=time::$(date +'%Y-%m-%d') - echo ::set-output name=commit_id::$GITHUB_SHA - echo ${{steps.commit.outputs.changes}} - - - name: Create or update comment - if: steps.commit.outputs.changes == 'changes' - uses: peter-evans/create-or-update-comment@v1 - with: - comment-id: ${{ steps.fc.outputs.comment-id }} - issue-number: ${{ github.event.pull_request.number }} - body: | - Re-rendered previews from the latest commit: - - See [preview of Bookdown here](${{ steps.build-components.outputs.bookdown_link }}) - - See [preview of Coursera version here](${{ steps.build-components.outputs.coursera_link }}) - - Download the [preview of .docx file](${{ steps.build-components.outputs.docx_link }}) - - _Updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ - edit-mode: replace - - - name: No comment if no changes - if: steps.commit.outputs.changes == 'no_changes' - uses: peter-evans/create-or-update-comment@v1 - with: - comment-id: ${{ steps.fc.outputs.comment-id }} - issue-number: ${{ github.event.pull_request.number }} - body: | - The latest commit did not produce rendering changes. - - _Updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ - edit-mode: replace diff --git a/.github/workflows/send-updates.yml b/.github/workflows/send-updates.yml index 0b0a6949..d2082b78 100644 --- a/.github/workflows/send-updates.yml +++ b/.github/workflows/send-updates.yml @@ -2,7 +2,6 @@ name: Sync Files -#---TRIGGER-START---# on: release: types: @@ -13,7 +12,6 @@ on: description: 'Tag to use?' required: true default: 'null' -#---TRIGGER-END----# jobs: sync: diff --git a/.github/workflows/starting-course.yml b/.github/workflows/starting-course.yml index ff4415d9..b2cab896 100644 --- a/.github/workflows/starting-course.yml +++ b/.github/workflows/starting-course.yml @@ -3,13 +3,10 @@ name: Starting a new course - -#---TRIGGER-START---# on: push: branches: [ main, staging ] workflow_dispatch: -#---TRIGGER-END---# jobs: # Run cleaning process only if workflow is triggered by not being in the Bookdown template anymore diff --git a/.github/workflows/style-and-sp-check.yml b/.github/workflows/style-and-sp-check.yml deleted file mode 100644 index 07899132..00000000 --- a/.github/workflows/style-and-sp-check.yml +++ /dev/null @@ -1,118 +0,0 @@ -# Candace Savonen Dec 2021 - -name: Style and spell check R markdowns - -#---TRIGGER-START---# -on: - pull_request: - branches: [ main, staging ] -#---TRIGGER-END---# - -jobs: - style-n-check: - runs-on: ubuntu-latest - container: - image: jhudsl/course_template - - steps: - - name: Checkout files - uses: actions/checkout@v2 - with: - fetch-depth: 0 - - - name: Configure git - run: | - git config --local user.email "itcrtrainingnetwork@gmail.com" - git config --local user.name "jhudsl-robot" - - branch_name='preview-${{ github.event.pull_request.number }}' - exists=$(git ls-remote https://${{ secrets.GH_PAT }}@github.com/$GITHUB_REPOSITORY $branch_name | wc -l | xargs) - if [[ $exists == 0 ]];then - echo branch doesnt exist - git checkout -b $branch_name - git push --set-upstream origin $branch_name - else - echo branch does exist - git fetch --all - git checkout $branch_name - git merge -s recursive --strategy-option=theirs origin/${{ github.head_ref }} - fi - shell: bash - - - name: Run spell check - id: spell_check_run - run: | - results=$(Rscript "scripts/spell-check.R") - echo "::set-output name=sp_chk_results::$results" - cat resources/spell_check_results.tsv - - - name: Archive spelling errors - uses: actions/upload-artifact@v2 - with: - name: spell-check-results - path: resources/spell_check_results.tsv - - - name: Commit spell check errors - run: | - branch_name='preview-${{ github.event.pull_request.number }}' - git add --force resources/spell_check_results.tsv - git commit -m 'Add spell check file' || echo "No changes to commit" - git pull --set-upstream origin $branch_name --allow-unrelated-histories - git push --force origin $branch_name || echo "No changes to commit" - - - name: Build components of the spell check comment - id: build-components - env: - GH_PAT: ${{ secrets.GH_PAT }} - run: | - branch_name='preview-${{ github.event.pull_request.number }}' - sp_error_url=https://raw.githubusercontent.com/${GITHUB_REPOSITORY}/$branch_name/resources/spell_check_results.tsv - echo ::set-output name=time::$(date +'%Y-%m-%d') - echo ::set-output name=commit_id::$GITHUB_SHA - echo ::set-output name=sp_error_url::$sp_error_url - - # Handle the commenting - - name: Find Comment - uses: peter-evans/find-comment@v1 - id: fc - with: - issue-number: ${{ github.event.pull_request.number }} - comment-author: 'github-actions[bot]' - body-includes: spelling errors - - - name: Spelling errors! - if: ${{ steps.spell_check_run.outputs.sp_chk_results >= 3 }} - uses: peter-evans/create-or-update-comment@v1 - with: - comment-id: ${{ steps.fc.outputs.comment-id }} - issue-number: ${{ github.event.pull_request.number }} - body: | - :warning: There are spelling errors that need to be addressed. [Read this guide for more info](https://github.com/jhudsl/OTTR_Template/wiki/Spell-check). - [Download the errors here.](${{ steps.build-components.outputs.sp_error_url }}) - _Comment updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ - edit-mode: replace - - - name: Check spell check results - fail if too many errors - if: ${{ steps.spell_check_run.outputs.sp_chk_results >= 3 }} - run: exit 1 - - - name: No spelling errors - if: ${{ steps.spell_check_run.outputs.sp_chk_results < 3 }} - uses: peter-evans/create-or-update-comment@v1 - with: - comment-id: ${{ steps.fc.outputs.comment-id }} - issue-number: ${{ github.event.pull_request.number }} - body: | - No spelling errors! :tada: - _Comment updated at ${{ steps.build-components.outputs.time }} with changes from ${{ steps.build-components.outputs.commit_id }}_ - edit-mode: replace - - - name: Run styler - run: Rscript -e "styler::style_file(list.files(pattern = 'Rmd$', recursive = TRUE, full.names = TRUE));warnings()" - - - name: Commit styled files - run: | - git add \*.Rmd - git add resources/spell_check_results.tsv - git commit -m 'Style Rmds' || echo "No changes to commit" - git push origin || echo "No changes to commit" diff --git a/.github/workflows/test-send-updates.yml b/.github/workflows/test-send-updates.yml index 76dfaa02..e810a6ea 100644 --- a/.github/workflows/test-send-updates.yml +++ b/.github/workflows/test-send-updates.yml @@ -2,7 +2,6 @@ name: Test Sync Files -#---TRIGGER-START---# on: workflow_dispatch: inputs: @@ -10,7 +9,6 @@ on: description: 'What repo to test on e.g. jhudsl/OTTR_Template_Test' required: true default: 'jhudsl/OTTR_Template_Test' -#---TRIGGER-END----# jobs: test-sync: diff --git a/.github/workflows/transfer-rendered-files.yml b/.github/workflows/transfer-rendered-files.yml index 61bca65c..89a16464 100644 --- a/.github/workflows/transfer-rendered-files.yml +++ b/.github/workflows/transfer-rendered-files.yml @@ -8,7 +8,6 @@ name: Bookdown to Leanpub repo copy over # Copy rendered notebooks to Leanpub repo -#---TRIGGER-START---# on: workflow_dispatch: workflow_run: @@ -16,7 +15,6 @@ on: branches: [ main, staging ] types: - completed -#---TRIGGER-END----# jobs: file-bookdown-pr: diff --git a/.github/workflows/url-checker.yml b/.github/workflows/url-checker.yml deleted file mode 100644 index 3e556851..00000000 --- a/.github/workflows/url-checker.yml +++ /dev/null @@ -1,42 +0,0 @@ -# Adapted from https://github.com/marketplace/actions/url-checker by Candace Savonen - -# This github actions tests URLs in the Rmd files, README, and CONTRIBUTING.md -name: Check URLs - -#---TRIGGER-START---# -on: - workflow_dispatch: - pull_request: - branches: [ main, staging ] -#---TRIGGER-END----# - -jobs: - url-check: - runs-on: ubuntu-latest - - steps: - - name: checkout repo - uses: actions/checkout@v2 - - - name: Login as jhudsl-robot - run: | - git config --local user.email "itcrtrainingnetwork@gmail.com" - git config --local user.name "jhudsl-robot" - - - name: URLs-checker - uses: urlstechie/urlchecker-action@master - with: - # Delete the cloned repository after running URLchecked (default is false) - cleanup: true - - # A comma-separated list of file types to cover in the URL checks - file_types: .Rmd,.md - - # Choose whether to include file with no URLs in the prints. - print_all: false - - # A comma separated links to exclude during URL checks - exclude_urls: https://jhudatascience.org/{Course_Name}} - - # choose if the force pass or not - force_pass : true diff --git a/config_automation.yml b/config_automation.yml new file mode 100644 index 00000000..573368e8 --- /dev/null +++ b/config_automation.yml @@ -0,0 +1,14 @@ +# Formatting Checks (run at pull request) +check-quizzes: yes +url-checker: yes +render-preview: yes +style-and-sp-check: yes + +# Rendering +render-bookdown: yes +render-leanpub: yes +render-coursera: yes + +# Docker specific +docker-build: yes + \ No newline at end of file diff --git a/index.Rmd b/index.Rmd index 8ad0d743..7e46307b 100644 --- a/index.Rmd +++ b/index.Rmd @@ -1,5 +1,5 @@ --- -title: "Course Name " +title: "Course Name" date: "`r format(Sys.time(), '%B, %Y')`" site: bookdown::bookdown_site documentclass: book @@ -13,5 +13,4 @@ output: toc: true --- - # About this Course {-} diff --git a/packages.bib b/packages.bib deleted file mode 100644 index 5120648d..00000000 --- a/packages.bib +++ /dev/null @@ -1,85 +0,0 @@ -@Manual{R-base, - title = {R: A Language and Environment for Statistical Computing}, - author = {{R Core Team}}, - organization = {R Foundation for Statistical Computing}, - address = {Vienna, Austria}, - year = {2021}, - url = {https://www.R-project.org/}, -} - -@Manual{R-bookdown, - title = {bookdown: Authoring Books and Technical Documents with R Markdown}, - author = {Yihui Xie}, - year = {2021}, - note = {R package version 0.24}, - url = {https://CRAN.R-project.org/package=bookdown}, -} - -@Manual{R-knitr, - title = {knitr: A General-Purpose Package for Dynamic Report Generation in R}, - author = {Yihui Xie}, - year = {2021}, - note = {R package version 1.37}, - url = {https://yihui.org/knitr/}, -} - -@Manual{R-rmarkdown, - title = {rmarkdown: Dynamic Documents for R}, - author = {JJ Allaire and Yihui Xie and Jonathan McPherson and Javier Luraschi and Kevin Ushey and Aron Atkins and Hadley Wickham and Joe Cheng and Winston Chang and Richard Iannone}, - year = {2021}, - note = {R package version 2.11}, - url = {https://CRAN.R-project.org/package=rmarkdown}, -} - -@Book{bookdown2016, - title = {bookdown: Authoring Books and Technical Documents with {R} Markdown}, - author = {Yihui Xie}, - publisher = {Chapman and Hall/CRC}, - address = {Boca Raton, Florida}, - year = {2016}, - note = {ISBN 978-1138700109}, - url = {https://bookdown.org/yihui/bookdown}, -} - -@Book{knitr2015, - title = {Dynamic Documents with {R} and knitr}, - author = {Yihui Xie}, - publisher = {Chapman and Hall/CRC}, - address = {Boca Raton, Florida}, - year = {2015}, - edition = {2nd}, - note = {ISBN 978-1498716963}, - url = {https://yihui.org/knitr/}, -} - -@InCollection{knitr2014, - booktitle = {Implementing Reproducible Computational Research}, - editor = {Victoria Stodden and Friedrich Leisch and Roger D. Peng}, - title = {knitr: A Comprehensive Tool for Reproducible Research in {R}}, - author = {Yihui Xie}, - publisher = {Chapman and Hall/CRC}, - year = {2014}, - note = {ISBN 978-1466561595}, - url = {http://www.crcpress.com/product/isbn/9781466561595}, -} - -@Book{rmarkdown2018, - title = {R Markdown: The Definitive Guide}, - author = {Yihui Xie and J.J. Allaire and Garrett Grolemund}, - publisher = {Chapman and Hall/CRC}, - address = {Boca Raton, Florida}, - year = {2018}, - note = {ISBN 9781138359338}, - url = {https://bookdown.org/yihui/rmarkdown}, -} - -@Book{rmarkdown2020, - title = {R Markdown Cookbook}, - author = {Yihui Xie and Christophe Dervieux and Emily Riederer}, - publisher = {Chapman and Hall/CRC}, - address = {Boca Raton, Florida}, - year = {2020}, - note = {ISBN 9780367563837}, - url = {https://bookdown.org/yihui/rmarkdown-cookbook}, -} - diff --git a/resources/Dockerfile b/resources/Dockerfile new file mode 100644 index 00000000..46fc78d0 --- /dev/null +++ b/resources/Dockerfile @@ -0,0 +1,19 @@ +FROM jhudsl/course_template +LABEL maintainer="your_email.com" + +#################### EXAMPLES OF INSTALLING PACKAGES ########################### +# Install a Linux/Ubuntu package +# RUN apt-get update && apt-get install -y --no-install-recommends \ +# package_name + +# Install a package from CRAN +# RUN Rscript -e "install.packages( \ +# c('package_name'))" + +# Install a package from Bioconductor +# RUN Rscript -e "options(warn = 2); BiocManager::install( \ +# c('package_name') + +# Add a python package +# RUN RUN pip3 install \ +# "somepackage==0.1.0" diff --git a/scripts/get_spell_errors.R b/scripts/get_spell_errors.R deleted file mode 100644 index 82e7cb6b..00000000 --- a/scripts/get_spell_errors.R +++ /dev/null @@ -1,77 +0,0 @@ -#!/usr/bin/env Rscript - -# Written by Candace Savonen Dec 2021 - -# Ran by GitHub actions, given a repository name and a GitHub PAT, get the most recent spell check results. - -library(magrittr) -library(optparse) - -option_list <- list( - optparse::make_option( - c("--repo"), - type = "character", - default = NULL, - help = "GitHub repository name, e.g. jhudsl/OTTR_Template", - ), - optparse::make_option( - c("--git_pat"), - type = "character", - default = NULL, - help = "GitHub personal access token", - ) -) - -# Read the arguments passed -opt_parser <- optparse::OptionParser(option_list = option_list) -opt <- optparse::parse_args(opt_parser) - -repo_name <- opt$repo -git_pat <- opt$git_pat - -if (!is.character(repo_name)) { - repo_name <- as.character(repo_name) -} - -if (!is.character(git_pat)) { - git_pat <- as.character(git_pat) -} - -# Declare URL -url <- paste0("https://api.github.com/repos/", repo_name, "/actions/artifacts") - -# Github api get -response <- httr::GET( - url, - httr::add_headers(Authorization = paste0("token ", git_pat)), - httr::accept_json() -) - -if (httr::http_error(response)) { - warning(paste0("url: ", url, " failed")) -} - -# Get content as JSON -artifacts <- httr::content(response, as = "parsed")$artifacts - -if (length(artifacts) < 1) { - warning("No results") -} - -# Make it a data frame -artifacts_df <- do.call(rbind.data.frame, as.list(artifacts)) - -# We only care about the spell check results and the most recent one -the_url <- artifacts_df %>% - dplyr::filter(name == "spell-check-results") %>% - dplyr::top_n(1, created_at) %>% - dplyr::pull(archive_download_url) - -# Github api get the location of the artifact -response <- httr::GET( - the_url, - httr::add_headers(Authorization = paste0("token ", git_pat)) -) - -# Print out download url -write(response$url, stdout()) diff --git a/scripts/get_the_gist.R b/scripts/get_the_gist.R deleted file mode 100644 index 4beb79e9..00000000 --- a/scripts/get_the_gist.R +++ /dev/null @@ -1,126 +0,0 @@ -# Handle Gists! - -library(magrittr) - -# Find .git root directory -root_dir <- rprojroot::find_root(rprojroot::has_dir(".git")) - -option_list <- list( - optparse::make_option( - opt_str = c("--gist_key"), - type = "character", - default = NULL, - help = "The key for what the spell check file for this pull request and repository is - In github actions will be: e.g. ${{ github.repository }}_spell_check_${{ github.event.pull_request.number }}", - ), - optparse::make_option( - c("--file"), - type = "character", - default = NULL, - help = "The file to be stored in the gist. Must be relative to base git repository", - ), - optparse::make_option( - opt_str = "--delete", type = "character", - default = "FALSE", help = "Needs a 'TRUE/FALSE' whether the gist should be deleted after we find it" - ), - optparse::make_option( - c("--git_pat"), - type = "character", - default = NULL, - help = "GitHub personal access token stored in a text file", - ), - optparse::make_option( - opt_str = c("-v", "--verbose"), type = "character", - default = "FALSE", help = "Needs a 'TRUE/FALSE' whether more messages should be printed" - ) -) - -# Read the arguments passed -opt_parser <- optparse::OptionParser(option_list = option_list) -opt <- optparse::parse_args(opt_parser) -opt$delete <- as.logical(opt$delete) -opt$verbose <- as.logical(opt$verbose) -opt$file <- file.path(root_dir, opt$file) - - -if (!file.exists(opt$file) && !opt$delete) { - stop(paste("Specified file:", opt$file, "does not exist")) -} - -# Make sure we can login before we continue -system(paste("gh auth login --with-token <", opt$git_pat)) - -get_the_gist <- function(user = "jhudsl-robot", - verbose = TRUE) { - - # Declare URL - url <- paste0("https://api.github.com/users/", user, "/gists?per_page=1000000") - - # Github api get - response <- httr::GET( - url, - httr::accept_json() - ) - - if (httr::http_error(response)) { - warning(paste0("url: ", url, " failed")) - } - - # Get content as JSON - gists <- httr::content(response, as = "parsed") - - - description_key <- unlist(gists)[grep("description", names(unlist(gists)))] - id <- unlist(gists)[grep("^id$", names(unlist(gists)))] - gist_urls <- unlist(gists)[grep("files.spell_check_results.tsv.raw_url", names(unlist(gists)))] - - gists_df <- data.frame(description_key, id, gist_urls) - - return(gists_df) -} - -gist_df <- get_the_gist() - - -if (nrow(gist_df) < 1 ){ - if (opt$verbose) warning("No gists found at all") - gist_target <- gist_df -} else { - gist_target <- gist_df %>% - dplyr::filter(description_key == opt$gist_key) -} - -if (nrow(gist_target) < 1 ) { - # If gist is not found: - if (opt$verbose) message(paste0("No gists match the key:", opt$gist_key)) - if (opt$delete) { - # Warn that there isn't anything to delete - warning("No gist to delete.") - } else { - # Create it - message(paste("Creating gist:", opt$gist_key)) - system(paste("gh gist create --public", opt$file, "-d", opt$gist_key)) - } -} else { - # If gist is found: - if (opt$delete) { - # Delete it - message(paste("Deleting gist:", opt$gist_key)) - system(paste("gh gist delete", gist_target$id)) - } else { - # Or update it - message(paste("Updating gist:", opt$gist_key)) - system(paste("gh gist edit", gist_target$id, "-f", opt$file, "--add", opt$file)) - } -} - - -if (!opt$delete) { - # Print out the url - gist_target <- get_the_gist() %>% - dplyr::filter(description_key == opt$gist_key) %>% - dplyr::pull(gist_urls) - - write(gist_target, stdout()) -} -