Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add the simplest CI with make #10982

Draft
wants to merge 64 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
64 commits
Select commit Hold shift + click to select a range
543b4d2
Add the simplest CI with make
HoloRin Apr 12, 2024
537e47c
just deps/rabbit first
HoloRin Apr 12, 2024
1ce0396
Make testing a plugin with make a reusable workflow
HoloRin Apr 12, 2024
85cb326
fix summary job
HoloRin Apr 12, 2024
8543db8
Add all the plugins
HoloRin Apr 12, 2024
593d919
Fix step name in reusable workflow
HoloRin Apr 15, 2024
b54ed38
Add the most basic test result caching
HoloRin Apr 15, 2024
2b8a7ef
fix artifact name collisions
HoloRin Apr 15, 2024
8d58080
fix testlogs path
HoloRin Apr 15, 2024
b03fac9
Fix copy-paste error
HoloRin Apr 15, 2024
128f10b
debug
HoloRin Apr 15, 2024
1fb622a
debug 2
HoloRin Apr 15, 2024
f177085
debug 3
HoloRin Apr 15, 2024
a363a75
try to get the cache path right
HoloRin Apr 15, 2024
afdbab6
account for empty cache
HoloRin Apr 15, 2024
0bff86b
split up tests
HoloRin Apr 15, 2024
83b0585
more cache fixes
HoloRin Apr 15, 2024
3913587
short timeout for pipeline development
HoloRin Apr 15, 2024
cca39f8
continue-on-error for dialyze for now
HoloRin Apr 16, 2024
ed540c9
slightly more intelligent cache key
HoloRin Apr 16, 2024
bcee6e0
fail-fast false
HoloRin Apr 16, 2024
22de8b1
must checkout the files to hash them
HoloRin Apr 16, 2024
a38618a
no continue-on-error
HoloRin Apr 16, 2024
1044497
Ignore dialyze errors for rabbitmq_ct_helpers & trust_store_http
HoloRin Apr 16, 2024
655a84a
Generate the deps/rabbit workflow with make
HoloRin Apr 17, 2024
d0517ea
try to fix caching again
HoloRin Apr 17, 2024
40c5764
Use a generated workflow for each plugin
HoloRin Apr 18, 2024
85cbf69
Also template test-make.yaml
HoloRin Apr 18, 2024
48fb2c9
Workaround the limit of 20 reusable workflows per workflow
HoloRin Apr 18, 2024
946ecfa
setup erlang before using erlang.mk
HoloRin Apr 18, 2024
86c833e
install ytt
HoloRin Apr 18, 2024
4e2b750
fix inputs. references
HoloRin Apr 18, 2024
8eadf14
fix another inputs. reference
HoloRin Apr 18, 2024
45ab6d2
update some cache flags
HoloRin Apr 24, 2024
4af5294
Handle the fact the github actions cache does not allows updates
HoloRin Apr 24, 2024
1a4c06d
trying to understand why save-always does not work
HoloRin Apr 24, 2024
058ea27
Try different cache actions
HoloRin Apr 25, 2024
c8b09b4
again rework caching
HoloRin Apr 25, 2024
6e80eed
debug caching
HoloRin Apr 25, 2024
e398f8b
Cache partial success for plugins
HoloRin Apr 25, 2024
bec47ae
Cache the initial 'make'
HoloRin Apr 25, 2024
dc30b64
add missing action param
HoloRin Apr 25, 2024
a3f468b
eliminate separate build step, since it's cached
HoloRin Apr 25, 2024
7936d30
install dotnet for testing deps/rabbit
HoloRin Apr 25, 2024
e135104
more cache key fixing
HoloRin Apr 25, 2024
6654fa3
Move test-make.template.yaml
HoloRin Apr 26, 2024
98b4a8b
Run xref at the project root
HoloRin Apr 26, 2024
5c04bc6
Temporarily run the plugin tests in parallel with deps/rabbit
HoloRin Apr 29, 2024
7785402
Symlink rabbit_federation_test_util for make
HoloRin Apr 29, 2024
62cb16e
Inject credentials for aws tests
HoloRin Apr 30, 2024
2d77477
Skip the aws integration tests
HoloRin Apr 30, 2024
84b9bb2
Avoid the need for all the extra artifacts
HoloRin Apr 30, 2024
4ad0bc0
Update glob for repo hash key
HoloRin May 1, 2024
6a9880e
Workaround actions/cache@v4 save-always not working as expected
HoloRin May 2, 2024
65aed64
Always recompute the previous attempt number
HoloRin May 2, 2024
1e466dc
Once again, the actions caches are immutable
HoloRin May 2, 2024
385635a
Fix dialyze error for deps/rabbit
HoloRin May 6, 2024
2eb3c6c
Avoid stale actions workflow generation
HoloRin May 6, 2024
8739458
regen actions workflows
HoloRin May 6, 2024
0ded9a7
try to add mixed version tests
HoloRin May 8, 2024
899bb10
Split test-make.yaml
HoloRin May 8, 2024
2f65ab2
use v3.12.x for mixed versions
HoloRin May 8, 2024
4a66358
Mixed versions on main branch should test against v3.13.x
HoloRin May 8, 2024
e5159cf
make mixed templating fixes
HoloRin May 10, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Once again, the actions caches are immutable
therefore all dimensions of the matrix must be included in the key,
otherwise the first to finish within the matrix, wins
  • Loading branch information
HoloRin committed May 6, 2024
commit 1e466dcfd2f74da47353966c0c3eac41efeeff85
52 changes: 28 additions & 24 deletions .github/workflows/templates/test-make.template.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,10 @@
#@ return names
#@ end

#@ def cache_prefix(name):
#@ return "${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-"+name+"-${{ matrix.metadata_store }}-${{ matrix.otp_version }}"
#@ end

#@ def test_plugin(name, needs, suites):
test-(@= name @):
name: Test (@= name @)
Expand All @@ -24,7 +28,7 @@
- khepri
timeout-minutes: 180
env:
SUCCESS_PATH: /home/runner/test-result-cache/(@= name @)/${{ matrix.metadata_store }}/${{ matrix.otp_version }}
CACHE_PATH: /home/runner/test-result-cache
steps:
#@ if name == "rabbit":
- name: INSTALL DOTNET
Expand All @@ -46,12 +50,12 @@
- name: RESTORE TEST RESULT CACHE
uses: actions/cache/restore@v4
with:
path: /home/runner/test-result-cache/
key: ${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-(@= name @)-${{ github.run_number }}-${{ github.run_attempt }}
path: ${{ env.CACHE_PATH }}
key: (@= cache_prefix(name) @)-${{ github.run_number }}-${{ github.run_attempt }}
restore-keys: |
${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-(@= name @)-${{ github.run_number }}-${{ steps.previous-attempt-outputs.number }}
${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-(@= name @)-${{ github.run_number }}-
${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-(@= name @)-
(@= cache_prefix(name) @)-${{ github.run_number }}-${{ steps.previous-attempt-outputs.number }}
(@= cache_prefix(name) @)-${{ github.run_number }}-
(@= cache_prefix(name) @)-
- name: PRINT CACHED RESULTS
run: |
set -x
Expand All @@ -64,27 +68,27 @@
elixir-version: 1.15
- name: PREPARE
run: |
mkdir -p ${{ env.SUCCESS_PATH }}
mkdir -p ${{ env.CACHE_PATH }}
- name: DIALYZE
run: |
if [[ -f ${{ env.SUCCESS_PATH }}/dialyze ]]; then
if [[ -f ${{ env.CACHE_PATH }}/dialyze ]]; then
echo "dialyze already passed for this key ${{ needs.xref.outputs.hash }}"
else
make -C deps/(@= name @) \
dialyze \
RABBITMQ_METADATA_STORE=${{ matrix.metadata_store }}
touch ${{ env.SUCCESS_PATH }}/dialyze
touch ${{ env.CACHE_PATH }}/dialyze
fi
continue-on-error: #@ name == "rabbitmq_ct_helpers" or name == "trust_store_http"
- name: EUNIT
run: |
if [[ -f ${{ env.SUCCESS_PATH }}/eunit ]]; then
if [[ -f ${{ env.CACHE_PATH }}/eunit ]]; then
echo "eunit already passed for this key ${{ needs.xref.outputs.hash }}"
else
make -C deps/(@= name @) \
eunit \
RABBITMQ_METADATA_STORE=${{ matrix.metadata_store }}
touch ${{ env.SUCCESS_PATH }}/eunit
touch ${{ env.CACHE_PATH }}/eunit
fi
#@ for suite in suites:
- name: CT (@= suite @)
Expand All @@ -94,20 +98,20 @@
#@ end
#@ end
run: |
if [[ -f ${{ env.SUCCESS_PATH }}/ct-(@= suite @) ]]; then
if [[ -f ${{ env.CACHE_PATH }}/ct-(@= suite @) ]]; then
echo "ct-(@= suite @) already passed for this key ${{ needs.xref.outputs.hash }}"
else
make -C deps/(@= name @) \
ct-(@= suite @) \
RABBITMQ_METADATA_STORE=${{ matrix.metadata_store }}
touch ${{ env.SUCCESS_PATH }}/ct-(@= suite @)
touch ${{ env.CACHE_PATH }}/ct-(@= suite @)
fi
#@ end
- name: SAVE TEST RESULT CACHE
uses: actions/cache/save@v4
with:
path: /home/runner/test-result-cache/
key: ${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-(@= name @)-${{ github.run_number }}-${{ github.run_attempt }}
key: (@= cache_prefix(name) @)-${{ github.run_number }}-${{ github.run_attempt }}
- name: UPLOAD TEST ARTIFACTS
if: always()
uses: actions/upload-artifact@v4.3.1
Expand All @@ -131,7 +135,7 @@
- khepri
timeout-minutes: 20
env:
SUCCESS_PATH: /home/runner/test-result-cache/rabbitmq_cli/${{ matrix.metadata_store }}/${{ matrix.otp_version }}
CACHE_PATH: /home/runner/test-result-cache
steps:
- name: RESTORE BUILT REPO
uses: actions/cache@v4
Expand All @@ -147,12 +151,12 @@
- name: RESTORE TEST RESULT CACHE
uses: actions/cache/restore@v4
with:
path: /home/runner/test-result-cache/
key: ${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-rabbitmq_cli-${{ github.run_number }}-${{ github.run_attempt }}
path: ${{ env.CACHE_PATH }}
key: (@= cache_prefix('rabbitmq_cli') @)-${{ github.run_number }}-${{ github.run_attempt }}
restore-keys: |
${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-rabbitmq_cli-${{ github.run_number }}-${{ steps.previous-attempt-outputs.number }}
${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-rabbitmq_cli-${{ github.run_number }}-
${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-rabbitmq_cli-
(@= cache_prefix('rabbitmq_cli') @)-${{ github.run_number }}-${{ steps.previous-attempt-outputs.number }}
(@= cache_prefix('rabbitmq_cli') @)-${{ github.run_number }}-
(@= cache_prefix('rabbitmq_cli') @)-
- name: PRINT CACHED RESULTS
run: |
set -x
Expand All @@ -165,23 +169,23 @@
elixir-version: 1.15
- name: PREPARE
run: |
mkdir -p ${{ env.SUCCESS_PATH }}
mkdir -p ${{ env.CACHE_PATH }}
- name: TEST
id: test
run: |
if [[ -f ${{ env.SUCCESS_PATH }}/checks ]]; then
if [[ -f ${{ env.CACHE_PATH }}/checks ]]; then
echo "checks already passed for this key ${{ needs.xref.outputs.hash }}"
else
make -C deps/rabbitmq_cli \
checks \
RABBITMQ_METADATA_STORE=${{ matrix.metadata_store }}
touch ${{ env.SUCCESS_PATH }}/checks
touch ${{ env.CACHE_PATH }}/checks
fi
- name: SAVE TEST RESULT CACHE
uses: actions/cache/save@v4
with:
path: /home/runner/test-result-cache/
key: ${{ runner.os }}-test-result-cache-${{ needs.xref.outputs.hash }}-rabbitmq_cli-${{ github.run_number }}-${{ github.run_attempt }}
key: (@= cache_prefix('rabbitmq_cli') @)-${{ github.run_number }}-${{ github.run_attempt }}
- name: UPLOAD TEST ARTIFACTS
if: always()
uses: actions/upload-artifact@v4.3.1
Expand Down
Loading