Skip to content

Merge pull request #23 from dfe-analytical-services/add_testthat2 #97

Merge pull request #23 from dfe-analytical-services/add_testthat2

Merge pull request #23 from dfe-analytical-services/add_testthat2 #97

Workflow file for this run

on:
push:
branches:
- master
- development
name: deploy-shiny
jobs:
deployShiny:
runs-on: ${{ matrix.config.os }}
name: ${{ matrix.config.os }} (${{ matrix.config.r }})
strategy:
fail-fast: false
matrix:
config:
- {os: ubuntu-latest, r: 'release'}
steps:
- name: Checkout code
uses: actions/checkout@v4
- uses: r-lib/actions/setup-r@v2
with:
use-public-rspm: true
- name: Set env vars (dev)
if: endsWith(github.ref, '/development')
run: |
echo "SHINYAPP_NAME='dev-ks5-transition-matrices'" >> $GITHUB_ENV
- name: Set env vars (prod)
if: endsWith(github.ref, '/main')
run: |
echo "SHINYAPP_NAME='ks5-transition-matrices'">> $GITHUB_ENV
- name: Install odbc dependencies
run: sudo apt-get install unixodbc-dev
- name: Install processx
shell: Rscript {0}
run: |
install.packages("processx")
- name: restore renv
uses: r-lib/actions/setup-renv@v2
- name: Install rsconnect
shell: Rscript {0}
run: |
if (!requireNamespace("renv", quietly = TRUE)) install.packages("renv")
renv::install("rsconnect")
# Tokens are stored as secrets in GitHub to make sure only DfE analysts can publish apps in our shiny.io area
# Navigate to Settings > Secrets to add and view secrets. These can also be things like admin login and passwords for SQL databases.
# Get in touch with the Stats Development team if you need to add the below secrets to publish to shinyapps.io
- name: Push to shiny.io
run: >
Rscript
-e "rsconnect::setAccountInfo(name = 'department-for-education', token = '${{secrets.SHINYAPPS_TOKEN}}', secret = '${{secrets.SHINYAPPS_SECRET}}')"
-e "rsconnect::deployApp(appName=${{env.SHINYAPP_NAME}}, forceUpdate = TRUE)"