-
-
Notifications
You must be signed in to change notification settings - Fork 681
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1,103 changed files
with
43,314 additions
and
42,258 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
# This file contains extra tests to run for specific BYOND versions. | ||
# This is useful for making sure we maintain compatibility with both older and newer versions, | ||
# while still having our main tests run on a guaranteed pinned version. | ||
|
||
# Format is version: map | ||
# Example: | ||
# 500.1337: runtimestation | ||
# 515.1627: runtimestation |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
# Highest byond client version allowed to be required by the byond world. Set to 9999 to disable the check flat out. | ||
# If the compiled world requires clients use a version higher than this, ci will fail. | ||
# for instance: if this is set to 514, and a pr uses a 515 client feature, an alert will trigger | ||
# If you have to update this number for your pr, you should make it VERY CLEAR in the pr body that you did so. | ||
# (Requiring clients update to connect to the game server is not something we like to spring on them with no notice, | ||
# especially for beta builds where the pager/updater won't let them update without additional configuration.) | ||
|
||
514 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,290 @@ | ||
name: CI Suite | ||
on: | ||
push: | ||
branches: | ||
- master | ||
- 'project/**' | ||
- 'gh-readonly-queue/master/**' | ||
- 'gh-readonly-queue/project/**' | ||
pull_request: | ||
branches: | ||
- master | ||
- 'project/**' | ||
merge_group: | ||
branches: | ||
- master | ||
|
||
concurrency: | ||
group: ${{ github.workflow }}-${{ github.ref }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
run_linters: | ||
if: ( !contains(github.event.head_commit.message, '[ci skip]') ) | ||
name: Run Linters | ||
runs-on: ubuntu-22.04 | ||
timeout-minutes: 5 | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Restore SpacemanDMM cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: ~/SpacemanDMM | ||
key: ${{ runner.os }}-spacemandmm-${{ hashFiles('dependencies.sh') }} | ||
restore-keys: | | ||
${{ runner.os }}-spacemandmm- | ||
- name: Restore Yarn cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: tgui/.yarn/cache | ||
key: ${{ runner.os }}-yarn-${{ hashFiles('tgui/yarn.lock') }} | ||
restore-keys: | | ||
${{ runner.os }}-yarn- | ||
- name: Restore Node cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: ~/.nvm | ||
key: ${{ runner.os }}-node-${{ hashFiles('dependencies.sh') }} | ||
restore-keys: | | ||
${{ runner.os }}-node- | ||
- name: Restore Bootstrap cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: tools/bootstrap/.cache | ||
key: ${{ runner.os }}-bootstrap-${{ hashFiles('tools/requirements.txt') }} | ||
restore-keys: | | ||
${{ runner.os }}-bootstrap- | ||
- name: Restore Rust cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: ~/.cargo | ||
key: ${{ runner.os }}-rust-${{ hashFiles('tools/ci/ci_dependencies.sh')}} | ||
restore-keys: | | ||
${{ runner.os }}-rust- | ||
- name: Restore Cutter cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: tools/icon_cutter/cache | ||
key: ${{ runner.os }}-cutter-${{ hashFiles('dependencies.sh') }} | ||
- name: Python setup | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: "3.11" | ||
- name: Install OpenDream | ||
uses: robinraju/[email protected] | ||
with: | ||
repository: "OpenDreamProject/OpenDream" | ||
tag: "latest" | ||
fileName: "DMCompiler_linux-x64.tar.gz" | ||
extract: true | ||
- name: Install Tools | ||
run: | | ||
pip3 install setuptools | ||
bash tools/ci/install_node.sh | ||
bash tools/ci/install_spaceman_dmm.sh dreamchecker | ||
bash tools/ci/install_ripgrep.sh | ||
tools/bootstrap/python -c '' | ||
- name: Setup linters | ||
id: linter-setup | ||
run: ':' | ||
- name: Run Grep Checks | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: bash tools/ci/check_grep.sh | ||
- name: Ticked File Enforcement | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: | | ||
tools/bootstrap/python tools/ticked_file_enforcement/ticked_file_enforcement.py < tools/ticked_file_enforcement/schemas/beestation_dme.json | ||
tools/bootstrap/python tools/ticked_file_enforcement/ticked_file_enforcement.py < tools/ticked_file_enforcement/schemas/unit_tests.json | ||
- name: Check Define Sanity | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: tools/bootstrap/python -m define_sanity.check | ||
- name: Check Trait Validity | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: tools/bootstrap/python -m trait_validity.check | ||
- name: Run DreamChecker | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
shell: bash | ||
run: ~/dreamchecker 2>&1 | bash tools/ci/annotate_dm.sh | ||
- name: Run OpenDream | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: ./DMCompiler_linux-x64/DMCompiler beestation.dme --suppress-unimplemented --define=CIBUILDING | bash tools/ci/annotate_od.sh | ||
- name: Run Map Checks | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: | | ||
tools/bootstrap/python -m mapmerge2.dmm_test | ||
tools/bootstrap/python -m tools.maplint.source | ||
- name: Check Cutter | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: tools/bootstrap/python -m tools.icon_cutter.check | ||
- name: Run DMI Tests | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: tools/bootstrap/python -m dmi.test | ||
- name: Check File Directories | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: bash tools/ci/check_filedirs.sh beestation.dme | ||
- name: Check Miscellaneous Files | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: bash tools/ci/check_misc.sh | ||
- name: Run TGUI Checks | ||
if: steps.linter-setup.conclusion == 'success' && !cancelled() | ||
run: tools/build/build --ci lint tgui-test | ||
|
||
compile_all_maps: | ||
if: ( !contains(github.event.head_commit.message, '[ci skip]') ) | ||
name: Compile Maps | ||
needs: [collect_data] | ||
runs-on: ubuntu-22.04 | ||
timeout-minutes: 5 | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Restore BYOND cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: ~/BYOND | ||
key: ${{ runner.os }}-byond-${{ hashFiles('dependencies.sh') }} | ||
- name: Compile All Maps | ||
run: | | ||
bash tools/ci/install_byond.sh | ||
source $HOME/BYOND/byond/bin/byondsetup | ||
tools/build/build --ci dm -DCIBUILDING -DCITESTING -DALL_MAPS | ||
- name: Check client Compatibility | ||
uses: tgstation/byond-client-compatibility-check@v3 | ||
with: | ||
dmb-location: beestation.dmb | ||
max-required-client-version: ${{needs.collect_data.outputs.max_required_byond_client}} | ||
|
||
collect_data: | ||
if: ( !contains(github.event.head_commit.message, '[ci skip]') ) | ||
name: Collect data for other tasks | ||
runs-on: ubuntu-22.04 | ||
timeout-minutes: 5 | ||
outputs: | ||
maps: ${{ steps.map_finder.outputs.maps }} | ||
alternate_tests: ${{ steps.alternate_test_finder.outputs.alternate_tests }} | ||
max_required_byond_client: ${{ steps.max_required_byond_client.outputs.max_required_byond_client }} | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Find Maps | ||
id: map_finder | ||
run: | | ||
echo "$(ls -mw0 _maps/*.json)" > maps_output.txt | ||
sed -i -e s+_maps/+\"+g -e s+.json+\"+g maps_output.txt | ||
echo "Maps: $(cat maps_output.txt)" | ||
echo "maps={\"paths\":[$(cat maps_output.txt)]}" >> $GITHUB_OUTPUT | ||
- name: Find Alternate Tests | ||
id: alternate_test_finder | ||
run: | | ||
ALTERNATE_TESTS_JSON=$(jq -nRc '[inputs | capture("^(?<major>[0-9]+)\\.(?<minor>[0-9]+): (?<map>.+)$")]' .github/alternate_byond_versions.txt) | ||
echo "alternate_tests=$ALTERNATE_TESTS_JSON" >> $GITHUB_OUTPUT | ||
- name: Collect byond client version configuration | ||
id: max_required_byond_client | ||
#the regex here does not filter out non-numbers because error messages about no input are less helpful then error messages about bad input (which includes the bad input) | ||
run: | | ||
echo "max_required_byond_client=$(grep -Ev '^[[:blank:]]{0,}#{1,}|^[[:blank:]]{0,}$' .github/max_required_byond_client.txt | tail -n1)" >> $GITHUB_OUTPUT | ||
run_all_tests: | ||
if: ( !contains(github.event.head_commit.message, '[ci skip]') ) | ||
name: Integration Tests | ||
needs: [collect_data] | ||
|
||
strategy: | ||
fail-fast: false | ||
matrix: | ||
map: ${{ fromJSON(needs.collect_data.outputs.maps).paths }} | ||
|
||
uses: ./.github/workflows/run_integration_tests.yml | ||
with: | ||
map: ${{ matrix.map }} | ||
max_required_byond_client: ${{needs.collect_data.outputs.max_required_byond_client}} | ||
|
||
run_alternate_tests: | ||
if: ( !contains(github.event.head_commit.message, '[ci skip]') && needs.collect_data.outputs.alternate_tests != '[]' ) | ||
name: Alternate Tests | ||
needs: [collect_data] | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
setup: ${{ fromJSON(needs.collect_data.outputs.alternate_tests) }} | ||
|
||
uses: ./.github/workflows/run_integration_tests.yml | ||
with: | ||
map: ${{ matrix.setup.map }} | ||
major: ${{ matrix.setup.major }} | ||
minor: ${{ matrix.setup.minor }} | ||
max_required_byond_client: ${{needs.collect_data.outputs.max_required_byond_client}} | ||
|
||
check_alternate_tests: | ||
if: ( !contains(github.event.head_commit.message, '[ci skip]') && needs.collect_data.outputs.alternate_tests != '[]' ) | ||
name: Check Alternate Tests | ||
needs: [run_alternate_tests, collect_data] | ||
runs-on: ubuntu-22.04 | ||
timeout-minutes: 5 | ||
steps: | ||
- run: echo Alternate tests passed. | ||
|
||
compare_screenshots: | ||
if: ( !contains(github.event.head_commit.message, '[ci skip]') && (always() && (!failure() && !cancelled())) ) | ||
needs: [run_all_tests, run_alternate_tests] | ||
name: Compare Screenshot Tests | ||
timeout-minutes: 15 | ||
runs-on: ubuntu-22.04 | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Setup directory | ||
run: mkdir -p artifacts | ||
# If we ever add more artifacts, this is going to break, but it'll be obvious. | ||
- name: Download screenshot tests | ||
uses: actions/download-artifact@v4 | ||
with: | ||
path: artifacts | ||
- name: ls -R | ||
run: ls -R artifacts | ||
- name: Setup screenshot comparison | ||
run: npm i | ||
working-directory: tools/screenshot-test-comparison | ||
- name: Run screenshot comparison | ||
run: node tools/screenshot-test-comparison/index.js artifacts code/modules/unit_tests/screenshots artifacts/screenshot_comparisons | ||
# workflow_run does not give you the PR it ran on, | ||
# even through the thing literally named "matching pull requests". | ||
# However, in GraphQL, you can check if the check suite was ran | ||
# by a specific PR, so trusting the (user controlled) action here is okay, | ||
# as long as we check it later in show_screenshot_test_results | ||
- name: Save PR ID | ||
if: failure() && github.event.pull_request | ||
run: | | ||
echo ${{ github.event.pull_request.number }} > artifacts/screenshot_comparisons/pull_request_number.txt | ||
- name: Upload bad screenshots | ||
if: failure() | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: bad-screenshots | ||
path: artifacts/screenshot_comparisons | ||
|
||
test_windows: | ||
if: ( !contains(github.event.head_commit.message, '[ci skip]') ) | ||
name: Windows Build | ||
needs: [collect_data] | ||
runs-on: windows-latest | ||
timeout-minutes: 5 | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Restore Yarn cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: tgui/.yarn/cache | ||
key: ${{ runner.os }}-yarn-${{ hashFiles('tgui/yarn.lock') }} | ||
restore-keys: | | ||
${{ runner.os }}-yarn- | ||
- name: Compile | ||
run: pwsh tools/ci/build.ps1 | ||
env: | ||
DM_EXE: "C:\\byond\\bin\\dm.exe" | ||
- name: Check client Compatibility | ||
uses: tgstation/byond-client-compatibility-check@v3 | ||
with: | ||
dmb-location: beestation.dmb | ||
max-required-client-version: ${{needs.collect_data.outputs.max_required_byond_client}} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
name: Rerun/Report Flaky Tests | ||
on: | ||
workflow_run: | ||
workflows: [CI Suite] | ||
types: | ||
- completed | ||
jobs: | ||
rerun_flaky_tests: | ||
runs-on: ubuntu-latest | ||
if: ${{ github.event.workflow_run.conclusion == 'failure' && github.event.workflow_run.run_attempt == 1 }} | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
- name: Rerun flaky tests | ||
uses: actions/github-script@v6 | ||
with: | ||
script: | | ||
const { rerunFlakyTests } = await import('${{ github.workspace }}/tools/pull_request_hooks/rerunFlakyTests.js') | ||
await rerunFlakyTests({ github, context }) | ||
report_flaky_tests: | ||
runs-on: ubuntu-latest | ||
if: ${{ github.event.workflow_run.conclusion == 'success' && github.event.workflow_run.run_attempt == 2 }} | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
- name: Report flaky tests | ||
uses: actions/github-script@v6 | ||
with: | ||
script: | | ||
const { reportFlakyTests } = await import('${{ github.workspace }}/tools/pull_request_hooks/rerunFlakyTests.js') | ||
await reportFlakyTests({ github, context }) |
Oops, something went wrong.