1# Generated from xtask::workflows::extension_tests
2# Rebuild with `cargo xtask workflows`.
3name: extension_tests
4env:
5 CARGO_TERM_COLOR: always
6 RUST_BACKTRACE: '1'
7 CARGO_INCREMENTAL: '0'
8 ZED_EXTENSION_CLI_SHA: 03d8e9aee95ea6117d75a48bcac2e19241f6e667
9 RUSTUP_TOOLCHAIN: stable
10 CARGO_BUILD_TARGET: wasm32-wasip2
11on:
12 workflow_call: {}
13jobs:
14 orchestrate:
15 if: (github.repository_owner == 'zed-industries' || github.repository_owner == 'zed-extensions')
16 runs-on: namespace-profile-2x4-ubuntu-2404
17 steps:
18 - name: steps::checkout_repo
19 uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
20 with:
21 clean: false
22 fetch-depth: ${{ github.ref == 'refs/heads/main' && 2 || 350 }}
23 - id: filter
24 name: filter
25 run: |
26 set -euo pipefail
27 if [ -z "$GITHUB_BASE_REF" ]; then
28 echo "Not in a PR context (i.e., push to main/stable/preview)"
29 COMPARE_REV="$(git rev-parse HEAD~1)"
30 else
31 echo "In a PR context comparing to pull_request.base.ref"
32 git fetch origin "$GITHUB_BASE_REF" --depth=350
33 COMPARE_REV="$(git merge-base "origin/${GITHUB_BASE_REF}" HEAD)"
34 fi
35 CHANGED_FILES="$(git diff --name-only "$COMPARE_REV" "$GITHUB_SHA")"
36
37 check_pattern() {
38 local output_name="$1"
39 local pattern="$2"
40 local grep_arg="$3"
41
42 echo "$CHANGED_FILES" | grep "$grep_arg" "$pattern" && \
43 echo "${output_name}=true" >> "$GITHUB_OUTPUT" || \
44 echo "${output_name}=false" >> "$GITHUB_OUTPUT"
45 }
46
47 check_pattern "check_rust" '^(Cargo.lock|Cargo.toml|.*\.rs)$' -qP
48 check_pattern "check_extension" '^(extension\.toml|.*\.scm)$' -qP
49 outputs:
50 check_rust: ${{ steps.filter.outputs.check_rust }}
51 check_extension: ${{ steps.filter.outputs.check_extension }}
52 check_rust:
53 needs:
54 - orchestrate
55 if: needs.orchestrate.outputs.check_rust == 'true'
56 runs-on: namespace-profile-8x32-ubuntu-2404
57 steps:
58 - name: steps::checkout_repo
59 uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
60 with:
61 clean: false
62 - name: steps::cache_rust_dependencies_namespace
63 uses: namespacelabs/nscloud-cache-action@v1
64 with:
65 cache: rust
66 path: ~/.rustup
67 - name: extension_tests::install_rust_target
68 run: rustup target add wasm32-wasip2
69 - name: steps::cargo_fmt
70 run: cargo fmt --all -- --check
71 - name: extension_tests::run_clippy
72 run: cargo clippy --release --all-features -- --deny warnings
73 - name: steps::cargo_install_nextest
74 uses: taiki-e/install-action@nextest
75 - name: steps::cargo_nextest
76 run: 'cargo nextest run --workspace --no-fail-fast --no-tests=warn --target "$(rustc -vV | sed -n ''s|host: ||p'')"'
77 env:
78 NEXTEST_NO_TESTS: warn
79 timeout-minutes: 6
80 check_extension:
81 needs:
82 - orchestrate
83 if: needs.orchestrate.outputs.check_extension == 'true'
84 runs-on: namespace-profile-8x32-ubuntu-2404
85 steps:
86 - name: steps::checkout_repo
87 uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
88 with:
89 clean: false
90 fetch-depth: 0
91 - id: cache-zed-extension-cli
92 name: extension_tests::cache_zed_extension_cli
93 uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830
94 with:
95 path: zed-extension
96 key: zed-extension-${{ env.ZED_EXTENSION_CLI_SHA }}
97 - name: extension_tests::download_zed_extension_cli
98 if: steps.cache-zed-extension-cli.outputs.cache-hit != 'true'
99 run: |
100 wget --quiet "https://zed-extension-cli.nyc3.digitaloceanspaces.com/$ZED_EXTENSION_CLI_SHA/x86_64-unknown-linux-gnu/zed-extension"
101 chmod +x zed-extension
102 - name: steps::cache_rust_dependencies_namespace
103 uses: namespacelabs/nscloud-cache-action@v1
104 with:
105 cache: rust
106 path: ~/.rustup
107 - name: extension_tests::check
108 run: |
109 mkdir -p /tmp/ext-scratch
110 mkdir -p /tmp/ext-output
111 ./zed-extension --source-dir . --scratch-dir /tmp/ext-scratch --output-dir /tmp/ext-output
112 - name: run_tests::fetch_ts_query_ls
113 uses: dsaltares/fetch-gh-release-asset@aa37ae5c44d3c9820bc12fe675e8670ecd93bd1c
114 with:
115 repo: ribru17/ts_query_ls
116 version: tags/v3.15.1
117 file: ts_query_ls-x86_64-unknown-linux-gnu.tar.gz
118 - name: run_tests::run_ts_query_ls
119 run: |-
120 tar -xf ts_query_ls-x86_64-unknown-linux-gnu.tar.gz
121 ./ts_query_ls format --check . || {
122 echo "Found unformatted queries, please format them with ts_query_ls."
123 echo "For easy use, install the Tree-sitter query extension:"
124 echo "zed://extension/tree-sitter-query"
125 false
126 }
127 - id: compare-versions-check
128 name: extension_bump::compare_versions
129 run: |
130 CURRENT_VERSION="$(sed -n 's/^version = \"\(.*\)\"/\1/p' < extension.toml | tr -d '[:space:]')"
131
132 if [[ "$GITHUB_EVENT_NAME" == "pull_request" ]]; then
133 PR_FORK_POINT="$(git merge-base origin/main HEAD)"
134 git checkout "$PR_FORK_POINT"
135 elif BRANCH_PARENT_SHA="$(git merge-base origin/main origin/zed-zippy-autobump)"; then
136 git checkout "$BRANCH_PARENT_SHA"
137 else
138 git checkout "$(git log -1 --format=%H)"~1
139 fi
140
141 PARENT_COMMIT_VERSION="$(sed -n 's/^version = \"\(.*\)\"/\1/p' < extension.toml | tr -d '[:space:]')"
142
143 [[ "$CURRENT_VERSION" == "$PARENT_COMMIT_VERSION" ]] && \
144 echo "version_changed=false" >> "$GITHUB_OUTPUT" || \
145 echo "version_changed=true" >> "$GITHUB_OUTPUT"
146
147 echo "current_version=${CURRENT_VERSION}" >> "$GITHUB_OUTPUT"
148 - name: extension_tests::verify_version_did_not_change
149 run: |
150 if [[ "$VERSION_CHANGED" == "true" && "$GITHUB_EVENT_NAME" == "pull_request" && "$PR_USER_LOGIN" != "zed-zippy[bot]" ]] ; then
151 echo "Version change detected in your change!"
152 echo "Version changes happen in separate PRs and will be performed by the zed-zippy bot"
153 exit 42
154 fi
155 env:
156 VERSION_CHANGED: ${{ steps.compare-versions-check.outputs.version_changed }}
157 PR_USER_LOGIN: ${{ github.event.pull_request.user.login }}
158 timeout-minutes: 6
159 tests_pass:
160 needs:
161 - orchestrate
162 - check_rust
163 - check_extension
164 if: (github.repository_owner == 'zed-industries' || github.repository_owner == 'zed-extensions') && always()
165 runs-on: namespace-profile-2x4-ubuntu-2404
166 steps:
167 - name: run_tests::tests_pass
168 run: |
169 set +x
170 EXIT_CODE=0
171
172 check_result() {
173 echo "* $1: $2"
174 if [[ "$2" != "skipped" && "$2" != "success" ]]; then EXIT_CODE=1; fi
175 }
176
177 check_result "orchestrate" "$RESULT_ORCHESTRATE"
178 check_result "check_rust" "$RESULT_CHECK_RUST"
179 check_result "check_extension" "$RESULT_CHECK_EXTENSION"
180
181 exit $EXIT_CODE
182 env:
183 RESULT_ORCHESTRATE: ${{ needs.orchestrate.result }}
184 RESULT_CHECK_RUST: ${{ needs.check_rust.result }}
185 RESULT_CHECK_EXTENSION: ${{ needs.check_extension.result }}
186concurrency:
187 group: ${{ github.workflow }}-${{ github.ref_name }}-${{ github.ref_name == 'main' && github.sha || 'anysha' }}
188 cancel-in-progress: true
189defaults:
190 run:
191 shell: bash -euxo pipefail {0}