Skip to content

Commit

Permalink
GitHub actions prs (#1129)
Browse files Browse the repository at this point in the history
* Update R_CMD_check_Hades.yaml

* Create R_CMD_check_sqlite_only.yaml

* skip test with unset variables

* skip test with unset variables

* skip on develop and main
  • Loading branch information
azimov authored Aug 14, 2024
1 parent ebb122c commit 9eabd7d
Show file tree
Hide file tree
Showing 6 changed files with 177 additions and 10 deletions.
5 changes: 3 additions & 2 deletions .github/workflows/R_CMD_check_Hades.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@
on:
push:
branches:
- '**'
- 'develop'
- 'main'
pull_request:
branches:
- '**'
- 'main'

name: R-CMD-check

Expand Down
154 changes: 154 additions & 0 deletions .github/workflows/R_CMD_check_sqlite_only.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,154 @@
# For help debugging build failures open an issue on the RStudio community with the 'github-actions' tag.
# https://community.rstudio.com/new-topic?category=Package%20development&tags=github-actions
on:
push:
branches:
- '**'
- '!develop'
- '!main'
pull_request:
branches:
- "**"
- '!main'
- "!develop"


name: R-CMD-check

jobs:
R-CMD-check:
runs-on: ${{ matrix.config.os }}

name: ${{ matrix.config.os }} (${{ matrix.config.r }})

strategy:
fail-fast: false
matrix:
config:
- {os: windows-latest, r: 'release'}
- {os: macOS-latest, r: 'release'}

env:
GITHUB_PAT: ${{ secrets.GH_TOKEN }}
R_REMOTES_NO_ERRORS_FROM_WARNINGS: true
RSPM: ${{ matrix.config.rspm }}
SKIP_DB_TESTS: "TRUE"

steps:
- uses: actions/checkout@v3

- uses: r-lib/actions/setup-r@v2
with:
r-version: ${{ matrix.config.r }}

- uses: r-lib/actions/setup-tinytex@v2

- uses: r-lib/actions/setup-pandoc@v2

- name: Install system requirements
if: runner.os == 'Linux'
run: |
sudo apt-get install -y libssh-dev
Rscript -e 'install.packages("remotes")'
while read -r cmd
do
eval sudo $cmd
done < <(Rscript -e 'writeLines(remotes::system_requirements("ubuntu", "20.04"))')
- uses: r-lib/actions/setup-r-dependencies@v2
with:
extra-packages: any::rcmdcheck
needs: check

- uses: r-lib/actions/check-r-package@v2
with:
args: 'c("--no-manual", "--as-cran")'
build_args: 'c("--compact-vignettes=both")'
error-on: '"warning"'
check-dir: '"check"'

- name: Upload source package
if: success() && runner.os == 'macOS' && github.event_name != 'pull_request' && github.ref == 'refs/heads/main'
uses: actions/upload-artifact@v2
with:
name: package_tarball
path: check/*.tar.gz

- name: Install covr
if: runner.os == 'macOS'
run: |
install.packages("covr")
shell: Rscript {0}

- name: Test coverage
if: runner.os == 'macOS'
run: covr::codecov()
shell: Rscript {0}

Release:
needs: R-CMD-Check

runs-on: macOS-latest

env:
GH_TOKEN: ${{ secrets.GH_TOKEN }}

if: ${{ github.event_name != 'pull_request' && github.ref == 'refs/heads/main' }}

steps:

- uses: actions/checkout@v3
with:
fetch-depth: 0

- name: Check if version has increased
run: |
echo "new_version="$(perl compare_versions --tag) >> $GITHUB_ENV
- name: Display new version number
if: ${{ env.new_version != '' }}
run: |
echo "${{ env.new_version }}"
- name: Create release
if: ${{ env.new_version != '' }}
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GH_TOKEN }}
with:
tag_name: ${{ env.new_version }}
release_name: Release ${{ env.new_version }}
body: |
See NEWS.md for release notes.
draft: false
prerelease: false

- uses: r-lib/actions/setup-r@v2
if: ${{ env.new_version != '' }}

- name: Install drat
if: ${{ env.new_version != '' }}
run: |
install.packages('drat')
shell: Rscript {0}

- name: Remove any tarballs that already exists
if: ${{ env.new_version != '' }}
run: |
rm -f *.tar.gz
- name: Download package tarball
if: ${{ env.new_version != '' }}
uses: actions/download-artifact@v2
with:
name: package_tarball

- name: Push to drat
if: ${{ env.new_version != '' }}
run: |
bash deploy.sh
- name: Push to BroadSea
if: ${{ env.new_version != '' }}
run: |
curl --data "build=true" -X POST https://registry.hub.docker.com/u/ohdsi/broadsea-methodslibrary/trigger/f0b51cec-4027-4781-9383-4b38b42dd4f5/
7 changes: 5 additions & 2 deletions tests/testOracle.R
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
library(testthat)
options(dbms = "oracle")
test_check("CohortDiagnostics")

if (Sys.getenv("SKIP_DB_TESTS") != "TRUE") {
options(dbms = "oracle")
test_check("CohortDiagnostics")
}
7 changes: 5 additions & 2 deletions tests/testPostgres.R
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
library(testthat)
options(dbms = "postgresql")
test_check("CohortDiagnostics")

if (Sys.getenv("SKIP_DB_TESTS") != "TRUE") {
options(dbms = "postgresql")
test_check("CohortDiagnostics")
}
7 changes: 5 additions & 2 deletions tests/testRedshift.R
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
library(testthat)
options(dbms = "redshift")
test_check("CohortDiagnostics")

if (Sys.getenv("SKIP_DB_TESTS") != "TRUE") {
options(dbms = "redshift")
test_check("CohortDiagnostics")
}
7 changes: 5 additions & 2 deletions tests/testSqlServer.R
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
library(testthat)
options(dbms = "sql server")
test_check("CohortDiagnostics")

if (Sys.getenv("SKIP_DB_TESTS") != "TRUE") {
options(dbms = "sql server")
test_check("CohortDiagnostics")
}

0 comments on commit 9eabd7d

Please sign in to comment.