diff --git a/.changelog/unreleased/bug-fixes/1756-pos-inflation-fix.md b/.changelog/unreleased/bug-fixes/1756-pos-inflation-fix.md new file mode 100644 index 0000000000..e8a1fcece1 --- /dev/null +++ b/.changelog/unreleased/bug-fixes/1756-pos-inflation-fix.md @@ -0,0 +1,2 @@ +- Fixes how PoS inflation is calculated. + ([\#1756](https://github.com/anoma/namada/pull/1756)) \ No newline at end of file diff --git a/.github/workflows/build-and-test.yml b/.github/workflows/build-and-test.yml index e274106660..b8a796dfc6 100644 --- a/.github/workflows/build-and-test.yml +++ b/.github/workflows/build-and-test.yml @@ -146,7 +146,7 @@ jobs: BUCKET_NAME: namada-wasm-master AWS_REGION: eu-west-1 - namada: + unit-and-integration-tests: runs-on: group: gians-runners timeout-minutes: 80 @@ -238,6 +238,12 @@ jobs: run: | wget -q -O- https://github.com/rui314/mold/releases/download/v${{ matrix.mold_version }}/mold-${{ matrix.mold_version }}-x86_64-linux.tar.gz | tar -xz mv mold-${{ matrix.mold_version }}-x86_64-linux/bin/mold /usr/local/bin + - name: Download MASP parameters + run: | + mkdir -p /home/runner/.masp-params + curl -o /home/runner/.masp-params/masp-spend.params -L https://github.com/anoma/masp-mpc/releases/download/namada-trusted-setup/masp-spend.params\?raw\=true + curl -o /home/runner/.masp-params/masp-output.params -L https://github.com/anoma/masp-mpc/releases/download/namada-trusted-setup/masp-output.params?raw=true + curl -o /home/runner/.masp-params/masp-convert.params -L https://github.com/anoma/masp-mpc/releases/download/namada-trusted-setup/masp-convert.params?raw=true - name: Download wasm artifacts uses: actions/download-artifact@v3 with: @@ -246,9 +252,10 @@ jobs: - uses: taiki-e/install-action@cargo-llvm-cov - name: Check crates build with default features run: make check-crates - - name: Run unit test - run: make test-unit-coverage${{ matrix.make.suffix }} + - name: Run unit and integration tests + run: make test-coverage${{ matrix.make.suffix }} env: + NAMADA_MASP_PARAMS_DIR: /home/runner/.masp-params RUSTFLAGS: "-C linker=clang -C link-arg=-fuse-ld=/usr/local/bin/mold" - name: Upload coverage uses: actions/upload-artifact@v3 @@ -386,6 +393,7 @@ jobs: os: [ubuntu-20.04] nightly_version: [nightly-2023-06-01] mold_version: [1.7.0] + comet_bft: [0.37.2] make: - name: e2e suffix: '' @@ -488,6 +496,12 @@ jobs: run: make build-test env: RUSTFLAGS: "-C linker=clang -C link-arg=-fuse-ld=/usr/local/bin/mold" + - name: Download MASP parameters + run: | + mkdir -p /home/runner/.masp-params + curl -o /home/runner/.masp-params/masp-spend.params -L https://github.com/anoma/masp-mpc/releases/download/namada-trusted-setup/masp-spend.params\?raw\=true + curl -o /home/runner/.masp-params/masp-output.params -L https://github.com/anoma/masp-mpc/releases/download/namada-trusted-setup/masp-output.params?raw=true + curl -o /home/runner/.masp-params/masp-convert.params -L https://github.com/anoma/masp-mpc/releases/download/namada-trusted-setup/masp-convert.params?raw=true - name: Wait for release binaries uses: lewagon/wait-on-check-action@v1.2.0 with: @@ -508,7 +522,7 @@ jobs: path: ./target/release/ - name: Download CometBFT run: | - curl -o cometbft.tar.gz -LO https://github.com/cometbft/cometbft/releases/download/v0.37.2/cometbft_0.37.2_linux_amd64.tar.gz + curl -o cometbft.tar.gz -LO https://github.com/cometbft/cometbft/releases/download/v${{ matrix.comet_bft }}/cometbft_${{ matrix.comet_bft }}_linux_amd64.tar.gz tar -xvzf cometbft.tar.gz mv cometbft /usr/local/bin - name: Change permissions @@ -522,6 +536,7 @@ jobs: run: | python3 .github/workflows/scripts/schedule-e2e.py env: + NAMADA_MASP_PARAMS_DIR: /home/runner/.masp-params NAMADA_E2E_USE_PREBUILT_BINARIES: "true" NAMADA_E2E_KEEP_TEMP: "true" NAMADA_TM_STDOUT: "false" diff --git a/.github/workflows/docs.yml b/.github/workflows/docs.yml index 986e278b19..12842ccfac 100644 --- a/.github/workflows/docs.yml +++ b/.github/workflows/docs.yml @@ -73,7 +73,7 @@ jobs: if: matrix.os == 'ubuntu-20.04' env: LINK: https://github.com/mozilla/sccache/releases/download - SCCACHE_VERSION: v0.3.0 + SCCACHE_VERSION: v0.5.4 run: | SCCACHE_FILE=sccache-$SCCACHE_VERSION-x86_64-unknown-linux-musl mkdir -p $HOME/.local/bin @@ -168,7 +168,7 @@ jobs: if: matrix.os == 'ubuntu-20.04' env: LINK: https://github.com/mozilla/sccache/releases/download - SCCACHE_VERSION: v0.3.0 + SCCACHE_VERSION: v0.5.4 run: | SCCACHE_FILE=sccache-$SCCACHE_VERSION-x86_64-unknown-linux-musl mkdir -p $HOME/.local/bin diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 7256b810b1..c909811c3e 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -50,7 +50,7 @@ jobs: if: matrix.os == 'ubuntu-20.04' env: LINK: https://github.com/mozilla/sccache/releases/download - SCCACHE_VERSION: v0.3.0 + SCCACHE_VERSION: v0.5.4 run: | SCCACHE_FILE=sccache-$SCCACHE_VERSION-x86_64-unknown-linux-musl mkdir -p $HOME/.local/bin diff --git a/.github/workflows/scripts/e2e.json b/.github/workflows/scripts/e2e.json index bf91fc1588..dac561ee98 100644 --- a/.github/workflows/scripts/e2e.json +++ b/.github/workflows/scripts/e2e.json @@ -6,9 +6,6 @@ "e2e::ledger_tests::invalid_transactions": 13, "e2e::ledger_tests::ledger_many_txs_in_a_block": 55, "e2e::ledger_tests::ledger_txs_and_queries": 30, - "e2e::ledger_tests::masp_incentives": 618, - "e2e::ledger_tests::masp_pinned_txs": 75, - "e2e::ledger_tests::masp_txs_and_queries": 282, "e2e::ledger_tests::pos_bonds": 77, "e2e::ledger_tests::pos_init_validator": 40, "e2e::ledger_tests::proposal_offline": 21, diff --git a/Makefile b/Makefile index 5e129b4b2c..19718cb782 100644 --- a/Makefile +++ b/Makefile @@ -116,11 +116,12 @@ audit: test: test-unit test-e2e test-wasm -test-unit-coverage: +# Integration and unit tests with coverage report +test-coverage: $(cargo) +$(nightly) llvm-cov --output-dir target \ --features namada/testing \ --html \ - -- --skip e2e --skip integration -Z unstable-options --report-time + -- --skip e2e -Z unstable-options --report-time # NOTE: `TEST_FILTER` is prepended with `e2e::`. Since filters in `cargo test` # work with a substring search, TEST_FILTER only works if it contains a string diff --git a/shared/src/ledger/inflation.rs b/shared/src/ledger/inflation.rs index 1c4850d2b1..055f52d6d9 100644 --- a/shared/src/ledger/inflation.rs +++ b/shared/src/ledger/inflation.rs @@ -63,10 +63,10 @@ impl RewardsController { // Token amounts must be expressed in terms of the raw amount (namnam) // to properly run the PD controller - let locked = - Dec::try_from(locked_tokens.raw_amount()).expect("Should not fail"); - let total = - Dec::try_from(total_tokens.raw_amount()).expect("Should not fail"); + let locked = Dec::try_from(locked_tokens.raw_amount()) + .expect("Should not fail to convert token Amount to Dec"); + let total = Dec::try_from(total_tokens.raw_amount()) + .expect("Should not fail to convert token Amount to Dec"); let epochs_py: Dec = epochs_per_year.into(); let locked_ratio = locked / total; @@ -78,17 +78,25 @@ impl RewardsController { let delta_error = locked_ratio_last - locked_ratio; let control_val = p_gain * error - d_gain * delta_error; - let last_inflation_amount = Dec::from(last_inflation_amount); - let new_inflation_amount = last_inflation_amount + control_val; - let inflation = if last_inflation_amount + control_val > max_inflation { + let control_val = token::Amount::from_uint( + control_val + .to_uint() + .expect("Should not fail to convert Dec to Uint"), + 0, + ) + .expect("Should not fail to convert Uint to Amount"); + + let max_inflation = token::Amount::from_uint( max_inflation - } else if new_inflation_amount > Dec::zero() { - new_inflation_amount - } else { - Dec::zero() - }; - let inflation = token::Amount::from(inflation); + .to_uint() + .expect("Should not fail to convert Dec to Uint"), + 0, + ) + .expect("Should not fail to convert Uint to Amount"); + + let new_inflation_amount = last_inflation_amount + control_val; + let inflation = std::cmp::min(new_inflation_amount, max_inflation); ValsToUpdate { locked_ratio, inflation,