name: Run QL Tests on: push: branches: [main] pull_request: branches: [main] env: CARGO_TERM_COLOR: always jobs: qltest: runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 - name: Fetch CodeQL run: | LATEST=$(gh release list --repo https://github.com/github/codeql-cli-binaries | cut -f 1 | sort --version-sort | tail -1) gh release download --repo https://github.com/github/codeql-cli-binaries --pattern codeql-linux64.zip "$LATEST" unzip -q codeql-linux64.zip env: GITHUB_TOKEN: ${{ github.token }} - uses: actions/cache@v2 with: path: | ~/.cargo/registry ~/.cargo/git target key: ${{ runner.os }}-qltest-cargo-${{ hashFiles('**/Cargo.lock') }} - name: Build Extractor run: env "PATH=$PATH:${{ github.workspace }}/codeql" ./create-extractor-pack.sh - name: Run QL tests run: codeql/codeql test run --check-databases --check-unused-labels --check-repeated-labels --check-redefined-labels --check-use-before-definition --search-path "${{ github.workspace }}" --consistency-queries ql/consistency-queries ql/test - name: Check QL formatting run: find ql "(" -name "*.ql" -or -name "*.qll" ")" -print0 | xargs -0 codeql/codeql query format --check-only - name: Check QL compilation run: codeql/codeql query compile --check-only --threads=4 --warnings=error --search-path "${{ github.workspace }}" "ql/src" "ql/examples"