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

feat: skip new contracts on check_storage_layout #974

Open
wants to merge 34 commits into
base: development
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 33 commits
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
e604f13
feat: remove newly added contracts from core storage change check wor…
zugdev Oct 3, 2024
d75ad0f
feat: add a new contract to test core contracts storage check workflow
zugdev Oct 4, 2024
be48114
feat: add a new variable with collision to test core contracts storag…
zugdev Oct 4, 2024
79c41d6
feat: read env to set-matrix workflow step
zugdev Oct 4, 2024
4911b86
feat: add a new variable with collision to test workflow
zugdev Oct 4, 2024
034c8b4
feat: add a new variable without colision to test storage workflow
zugdev Oct 4, 2024
486386e
feat: add another variable with collision to check storage check work…
zugdev Oct 4, 2024
09bb1bf
feat: add random comments to test storage check workflow
zugdev Oct 4, 2024
76732cb
chore: delete test workflow contract
zugdev Oct 4, 2024
9559223
feat: remove fork branch from branches in workflow
zugdev Oct 4, 2024
9ed317f
feat: add new contract storage check should skip
zugdev Oct 4, 2024
18623bb
feat: fix storage check workflow to check against development branch
zugdev Oct 4, 2024
a7e0375
chore: remove workflow test contract
zugdev Oct 4, 2024
7bb1c7b
feat: test storage check workflow contract creation should skip
zugdev Oct 4, 2024
a6477bc
feat: add a new variable to new contract should skip
zugdev Oct 4, 2024
8113e5e
feat: modify a core contract to test storage check workflow should no…
zugdev Oct 5, 2024
58ca4e4
feat: fix char put out in workflow
zugdev Oct 5, 2024
6513217
feat: modify a core contract with collision to test storage check wor…
zugdev Oct 5, 2024
6c698c9
feat: remove test workflow changes from core contract
zugdev Oct 5, 2024
f344231
feat: add a non colliding variable to core contract to test storage c…
zugdev Oct 5, 2024
f217ecb
feat: remove workflow test variable
zugdev Oct 5, 2024
6f1f50f
feat: test storage check on no storage update
zugdev Oct 5, 2024
ed7f656
feat: remove testing comments
zugdev Oct 5, 2024
61bba9d
test: delete workflow testing contract
zugdev Oct 16, 2024
b601e97
feat: skip new constracts in check diamond storage
zugdev Oct 16, 2024
69d35e9
test(storage-workflows): should skip new contract and new lib
zugdev Oct 16, 2024
9c940e8
test(storage-workflows): should skip new contract even after first co…
zugdev Oct 16, 2024
2953cb8
test(storage-workflow): should fail if core / diamond storage is chan…
zugdev Oct 16, 2024
88fa459
test(storage-workflow): should fail if core / diamond storage is chan…
zugdev Oct 16, 2024
ad8b124
test(storage-workflow): should fail if core / diamond storage is chan…
zugdev Oct 16, 2024
f8b5c3f
test(storage-workflow): should pass if core / diamond storage is chan…
zugdev Oct 17, 2024
4bdfffa
feat: add a workflow to generate storage artifacts
zugdev Oct 17, 2024
b44ea46
fix: storage artifacts generation workflow
zugdev Oct 17, 2024
c95eaa0
feat: polish storage-check
zugdev Oct 19, 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
28 changes: 22 additions & 6 deletions .github/workflows/core-contracts-storage-check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,18 @@ on:
push:
branches:
- development
- fix-core-contracts-storage-check
zugdev marked this conversation as resolved.
Show resolved Hide resolved
pull_request:

jobs:
provide_contracts:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
with:
submodules: recursive
fetch-depth: 2 # Ensure we can access the previous commit
zugdev marked this conversation as resolved.
Show resolved Hide resolved

- name: Install Foundry
uses: onbjerg/foundry-toolchain@v1
Expand All @@ -35,10 +37,25 @@ jobs:
env:
CHANGED_CONTRACTS: ${{ steps.changed-contracts.outputs.contracts_all_changed_files }}
run: |
for CONTRACT in "$CHANGED_CONTRACTS"; do
echo ${CONTRACT} | xargs basename -a | cut -d'.' -f1 | xargs -I{} echo src/dollar/core/{}.sol:{} >> contracts.txt
touch contracts.txt

# Fetch the latest state of the development branch to compare
git fetch origin development

# Iterate through changed contracts and check if they existed in the development branch
for CONTRACT in $CHANGED_CONTRACTS; do
if git show origin/development:$CONTRACT > /dev/null 2>&1; then
# If the contract existed in the development branch, add it to the list for storage check
echo ${CONTRACT} | xargs basename -a | cut -d'.' -f1 | xargs -I{} echo src/dollar/core/{}.sol:{} >> contracts.txt
else
echo "$CONTRACT is a new contract, skipping storage check."
fi
done
echo "matrix=$(cat contracts.txt | jq -R -s -c 'split("\n")[:-1]')" >> $GITHUB_OUTPUT

# Set the matrix only if there are contracts to check
if [ -s contracts.txt ]; then
echo "matrix=$(cat contracts.txt | jq -R -s -c 'split("\n")[:-1]')" >> $GITHUB_OUTPUT
fi

outputs:
matrix: ${{ steps.set-matrix.outputs.matrix }}
Expand Down Expand Up @@ -67,5 +84,4 @@ jobs:
with:
workingDirectory: packages/contracts
contract: ${{ matrix.contract }}
failOnRemoval: true

failOnRemoval: true
28 changes: 22 additions & 6 deletions .github/workflows/diamond-storage-check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ on:
push:
branches:
- development
- fix-core-contracts-storage-check
zugdev marked this conversation as resolved.
Show resolved Hide resolved
paths:
- '**.sol'
pull_request:
Expand All @@ -15,9 +16,10 @@ jobs:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
with:
submodules: recursive
fetch-depth: 2

- name: Install Foundry
uses: onbjerg/foundry-toolchain@v1
Expand All @@ -39,10 +41,25 @@ jobs:
env:
CHANGED_LIBS: ${{ steps.changed-libraries.outputs.libraries_all_changed_files }}
run: |
for DIAMOND_LIB in "$CHANGED_LIBS"; do
echo ${DIAMOND_LIB} | xargs basename -a | cut -d'.' -f1 | xargs -I{} echo src/dollar/libraries/{}.sol:{} >> contracts.txt
touch contracts.txt

# Fetch the latest state of the development branch to compare
git fetch origin development

# Iterate through changed libraries and check if they existed in the development branch
for DIAMOND_LIB in $CHANGED_LIBS; do
if git show origin/development:$DIAMOND_LIB > /dev/null 2>&1; then
# If the library existed in the development branch, add it to the list for storage check
echo ${DIAMOND_LIB} | xargs basename -a | cut -d'.' -f1 | xargs -I{} echo src/dollar/libraries/{}.sol:{} >> contracts.txt
else
echo "$DIAMOND_LIB is a new library, skipping storage check."
fi
done
echo "matrix=$(cat contracts.txt | jq -R -s -c 'split("\n")[:-1]')" >> $GITHUB_OUTPUT

# Set the matrix only if there are libraries to check
if [ -s contracts.txt ]; then
echo "matrix=$(cat contracts.txt | jq -R -s -c 'split("\n")[:-1]')" >> $GITHUB_OUTPUT
fi

outputs:
matrix: ${{ steps.set-matrix.outputs.matrix }}
Expand Down Expand Up @@ -71,5 +88,4 @@ jobs:
with:
workingDirectory: packages/contracts
contract: ${{ matrix.contract }}
failOnRemoval: true
failOnLabelDiff: true
failOnRemoval: true
64 changes: 64 additions & 0 deletions .github/workflows/generate-storage-artifacts.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
name: Generate Storage Artifacts

on:
workflow_dispatch
zugdev marked this conversation as resolved.
Show resolved Hide resolved

jobs:
provide_contracts:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
with:
submodules: recursive

- name: Install Foundry
uses: onbjerg/foundry-toolchain@v1
with:
version: nightly

- name: Set contracts matrix for all matching contracts
id: set-matrix
working-directory: packages/contracts
run: |
# Collect all contracts from core and libraries
CONTRACTS="$(find src/dollar/core/*.sol src/dollar/libraries/Lib*.sol -type f)"

for CONTRACT in $CONTRACTS; do
# Extract the contract name without the .sol extension
CONTRACT_NAME=$(basename "$CONTRACT" .sol)

# Write <contract path>:<contract name> to contracts.txt
echo "${CONTRACT}:${CONTRACT_NAME}" >> contracts.txt
done

# Set the matrix output
echo "matrix=$(cat contracts.txt | jq -R -s -c 'split("\n")[:-1]')" >> $GITHUB_OUTPUT

outputs:
matrix: ${{ steps.set-matrix.outputs.matrix }}

check_storage_layout:
needs: provide_contracts
runs-on: ubuntu-latest
if: ${{ needs.provide_contracts.outputs.matrix != '[]' && needs.provide_contracts.outputs.matrix != '' }}

strategy:
matrix:
contract: ${{ fromJSON(needs.provide_contracts.outputs.matrix) }}

steps:
- uses: actions/checkout@v3
with:
submodules: recursive

- name: Install Foundry
uses: onbjerg/foundry-toolchain@v1
with:
version: nightly

- name: Check For Core Contracts Storage Changes
uses: Rubilmax/foundry-storage-check@main
with:
workingDirectory: packages/contracts
contract: ${{ matrix.contract }}
2 changes: 2 additions & 0 deletions packages/contracts/src/dollar/core/ERC20Ubiquity.sol
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ abstract contract ERC20Ubiquity is
ERC20PermitUpgradeable,
ERC20PausableUpgradeable
{
// this is a non-colliding change
zugdev marked this conversation as resolved.
Show resolved Hide resolved

/// @notice Token symbol
string private _symbol;

Expand Down
7 changes: 7 additions & 0 deletions packages/contracts/src/dollar/core/ThisIsATest.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity 0.8.19;

contract ThisIsATest {
address var2;
address var1;
}
2 changes: 2 additions & 0 deletions packages/contracts/src/dollar/libraries/LibAppStorage.sol
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ import "./Constants.sol";

/// @notice Shared struct used as a storage in the `LibAppStorage` library
struct AppStorage {
// this is a non-colliding change

// reentrancy guard
uint256 reentrancyStatus;
// others
Expand Down
10 changes: 10 additions & 0 deletions packages/contracts/src/dollar/libraries/LibThisIsATest.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity 0.8.19;

library ThisIsATest {
function test() external pure {
address var2;
uint256 var1;
var1++;
}
}
Loading