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

Fix Serde Json Wasm issue #16

Merged
merged 10 commits into from
May 13, 2024
Merged

Fix Serde Json Wasm issue #16

merged 10 commits into from
May 13, 2024

Conversation

maxrobot
Copy link
Contributor

@maxrobot maxrobot commented Mar 19, 2024

See changes for more important information that I am omitting from my context description here............

Summary by CodeRabbit

  • Documentation
    • Updated the Changelog with version details and fixes.
  • New Features
    • Added structures for handling swap-related messages in a Cosmos SDK contract.
    • Integrated modules for integration logic tests and realistic tests in the swap contract.
    • Provided an example for contract admin to authorize other addresses for contract calls.
  • Bug Fixes
    • Improved migration logic in the migrate function within the contract.
  • Refactor
    • Adjusted settings in Cargo.toml related to resolver, release profiles, and dependencies.
  • Tests
    • Introduced test functions for setting routes for third-party trading and executing trades in the swap contract.
  • Chores
    • Made changes to the workflow file for building WASM contracts.

Copy link

coderabbitai bot commented Mar 19, 2024

Walkthrough

The recent updates involve version upgrades, bug fixes, and feature additions across various files. Version 1.0.2 includes updating serde-json-wasm, enhancing performance and compatibility. Version 1.0.1 introduced essential components like the Changelog file, rust-toolchain, contract migration templates, and a migrate function. It also resolved rounding issues and upgraded to the latest CosmWasm version for improved functionality.

Changes

Files/Groups of Files Change Summary
serde-json-wasm Version bump in 1.0.2
Changelog.md, rust-toolchain Introduced in 1.0.1
Contract migration templates, migrate function Added in `1.0.1 for enhanced contract management
Fixes (rounding, CosmWasm version) Addressed rounding issues and updated to the latest CosmWasm version in 1.0.1

🐰✨
In the realm of code, where logic intertwines,
A rabbit hopped through, leaving updates behind.
"To improve, to fix," it cheerfully said,
With every version bump, ahead it sped.
So here's to the changes, both big and small,
May they bring success, to one and all.
🌟📜


Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai generate interesting stats about this repository and render them as a table.
    • @coderabbitai show all the console.log statements in this repository.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (invoked as PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger a review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai help to get help.

Additionally, you can add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.

CodeRabbit Configration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@maxrobot maxrobot changed the title bump Fix Serde Json Wasm issue Mar 19, 2024
@maxrobot maxrobot requested a review from jbernal87 March 19, 2024 16:54
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Review Status

Actionable comments generated: 0

Configuration used: CodeRabbit UI

Commits Files that changed from the base of the PR and between be2f46d and fd55e7f.
Files ignored due to path filters (2)
  • Cargo.lock is excluded by: !**/*.lock
  • contracts/swap/Cargo.toml is excluded by: !**/*.toml
Files selected for processing (1)
  • Changelog.md (2 hunks)
Additional comments: 2
Changelog.md (2)
  • 19-23: The update for version 1.0.2 is clearly documented, focusing on the bump in version of serde-json-wasm. This change is crucial for maintaining compatibility and possibly enhancing serialization and deserialization efficiencies within the project's WebAssembly components.
  • 25-31: The documentation for version 1.0.1 effectively captures the introduction of the Changelog file, rust-toolchain file, contract migration templates, and a migrate function. Additionally, the fix for correctly rounding to min_quantity_tick_size in intermediate steps for multi-hop buys is a significant improvement, addressing precision issues.

Copy link
Member

@gorgos gorgos left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Tests failing, also whats up with that CodeRabbit description, it doesn't match what is actually in this PR.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 2

Review Status

Configuration used: CodeRabbit UI

Commits Files that changed from the base of the PR and between fd55e7f and a088c23.
Files selected for processing (5)
  • contracts/swap/msg.rs (1 hunks)
  • contracts/swap/src/testing/integration_tests/integration_logic_tests.rs (1 hunks)
  • contracts/swap/src/testing/integration_tests/integration_realistic_tests_exact_quantity.rs (1 hunks)
  • contracts/swap/src/testing/integration_tests/integration_realistic_tests_min_quantity.rs (1 hunks)
  • contracts/swap/src/testing/integration_tests/mod.rs (1 hunks)
Files not summarized due to errors (3)
  • contracts/swap/src/testing/integration_tests/integration_logic_tests.rs: Error: Message exceeds token limit
  • contracts/swap/src/testing/integration_tests/integration_realistic_tests_exact_quantity.rs: Error: Message exceeds token limit
  • contracts/swap/src/testing/integration_tests/integration_realistic_tests_min_quantity.rs: Error: Message exceeds token limit
Additional comments not posted (34)
contracts/swap/msg.rs (1)

1-70: The changes in msg.rs are well-structured and follow best practices for defining message handling in a CosmWasm contract. The use of serialization attributes, custom types, and clear struct and enum definitions contribute to a maintainable and understandable codebase. Ensure that all new types and operations are covered by unit tests to verify their correctness and behavior.

contracts/swap/src/testing/integration_tests/integration_realistic_tests_min_quantity.rs (6)

38-228: The test happy_path_two_hops_swap_eth_atom_realistic_values_self_relaying is well-structured and covers a comprehensive set of assertions to validate the swap functionality. However, consider adding more detailed comments explaining the rationale behind specific values used in the test, especially those derived from external sources or calculations. This will enhance maintainability and understandability for future contributors.


230-419: The test happy_path_two_hops_swap_inj_eth_realistic_values_self_relaying follows a similar pattern to the first test, effectively testing the swap functionality from INJ to ETH. It's crucial to ensure that the hardcoded values, especially those related to market conditions and expected outcomes, are kept up-to-date with realistic scenarios. Regular updates or a dynamic way to fetch these values might be necessary to keep the tests relevant.


422-612: In happy_path_two_hops_swap_inj_atom_realistic_values_self_relaying, the assertions for swap results and contract balances are clear and concise. To further improve test robustness, consider scenarios where market conditions might lead to unexpected results, such as insufficient liquidity or price slippage, and ensure these cases are handled gracefully in the test or the underlying code.


615-829: The test it_executes_swap_between_markets_using_different_quote_assets_self_relaying introduces a scenario with different quote assets, adding complexity to the swap process. It's commendable that the test checks for precise amounts post-swap and contract balance integrity. To enhance the test, consider edge cases where conversion rates between quote assets significantly fluctuate during the swap process, potentially affecting the expected outcomes.


832-968: The test it_doesnt_lose_buffer_if_executed_multiple_times is crucial for ensuring that repeated swap executions do not lead to unexpected loss of funds or accumulation of dust. The loop construct used to simulate multiple swaps is effective. However, it's important to also consider the impact of transaction fees on the contract's balance over multiple iterations, as this could affect the accuracy of the test's assertions.


1281-1415: The test it_returns_all_funds_if_there_is_not_enough_buffer_realistic_values effectively simulates a scenario where the swap cannot be executed due to insufficient funds. This test is crucial for ensuring the integrity of user funds in failure scenarios. To further enhance this test, consider adding more varied scenarios of insufficient funds, including cases with different assets and market conditions.

contracts/swap/src/testing/integration_tests/integration_realistic_tests_exact_quantity.rs (6)

23-37: The introductory comment block provides a good overview of the test suite's purpose and the source of the market parameters. However, it could be enhanced by briefly explaining the significance of the tests and how they contribute to ensuring the contract's reliability and functionality.

Consider expanding the comment to include a brief explanation of how these tests contribute to the overall reliability and functionality of the contract.


41-254: The tests it_swaps_eth_to_get_minimum_exact_amount_of_atom_by_mildly_rounding_up through it_swaps_inj_to_get_minimum_exact_amount_of_atom_by_mildly_rounding_up follow a similar pattern, calling a template function with different parameters. This approach is good for reducing code duplication and ensuring consistency across tests. However, there's an opportunity to further improve these tests by adding comments that explain the significance of each test case, especially the rationale behind the chosen parameters.

Consider adding comments to each test case to explain the significance of the chosen parameters and what specific scenario or edge case is being tested. This will improve the readability and maintainability of the test suite.


68-252: The test it_correctly_swaps_eth_to_get_very_high_exact_amount_of_atom and similar tests for swapping INJ to ATOM and INJ to ETH are comprehensive and cover a wide range of operations, including initializing accounts with funds, launching markets, setting up orders, and executing swaps. These tests are well-structured and provide a thorough examination of the swap functionality under realistic conditions. However, there's a potential improvement in how the expected outcomes are verified, particularly in asserting the exact amounts received and the contract's balance changes.

Consider adding more granular assertions to verify the state of the system after the swap operations. For example, in addition to checking the balances of the swapper and the contract, you could assert the state of the order book to ensure that orders were matched as expected. This would provide a more comprehensive validation of the swap functionality.


687-895: The test it_correctly_swaps_between_markets_using_different_quote_assets_self_relaying demonstrates a complex scenario involving swapping between markets with different quote assets. This test is crucial for verifying the contract's ability to handle swaps across different market types. The setup and execution of the test are well done, but there's a minor opportunity for improvement in the clarity of the test's purpose and the specific conditions it aims to validate.

Enhance the clarity of the test by adding a comment at the beginning that explicitly states the purpose of the test and the specific conditions or edge cases it aims to validate. This will help future maintainers understand the test's intent more quickly.


898-1032: The test it_doesnt_lose_buffer_if_exact_swap_of_eth_to_atom_is_executed_multiple_times is an important test for ensuring the contract's robustness over multiple iterations of the same swap operation. The use of a loop to execute the swap multiple times is a good approach to simulate repeated operations. However, there's an opportunity to improve the test by verifying the state of the system after each iteration, rather than only at the end.

Consider adding assertions within the loop to verify the state of the system after each swap operation. This could include checking the balances of the swapper and the contract, as well as the state of the order book. This would provide a more detailed insight into how the system behaves over multiple iterations and help catch any issues that might only manifest after several operations.


1035-1172: The test it_reverts_when_funds_provided_are_below_required_to_get_exact_amount effectively verifies that the contract correctly reverts when the provided funds are insufficient for the desired swap. This test is crucial for ensuring the contract's security and preventing unintended behavior. The structure and execution of the test are well done. However, there's a minor opportunity to improve the clarity of the error message assertion.

Consider using a more specific assertion method or library function that directly checks for the presence of the expected error message, rather than using contains on the error's string representation. This would make the test more robust and less susceptible to changes in the error formatting.

contracts/swap/src/testing/integration_tests/integration_logic_tests.rs (21)

31-171: The test it_executes_a_swap_between_two_base_assets_with_multiple_price_levels is comprehensive, covering the setup, execution, and validation of a swap between two base assets with multiple price levels. However, consider adding more detailed comments explaining the rationale behind each step and assertion to improve maintainability and readability for future developers.


173-292: The test it_executes_a_swap_between_two_base_assets_with_single_price_level effectively validates the swap functionality with a single price level. To enhance the test's clarity and maintainability, consider adding comments that detail the test's purpose and the significance of each assertion.


295-434: The test it_executes_swap_between_markets_using_different_quote_assets is well-structured and tests an important scenario. However, it would benefit from additional comments explaining the setup and expected outcomes, especially regarding the handling of different quote assets and fees, to aid in understanding and future maintenance.


437-564: The test it_reverts_swap_between_markets_using_different_quote_asset_if_one_quote_buffer_is_insufficient correctly simulates a failure scenario due to an insufficient quote buffer. Enhancing this test with more detailed comments explaining the setup and expected failure conditions would improve its readability and maintainability.


567-687: The test it_executes_a_sell_of_base_asset_to_receive_min_output_quantity effectively validates the sell operation with a minimum output quantity. Adding comments to explain the logic behind the calculations and assertions would make the test more accessible to future developers.


689-851: The test it_executes_a_buy_of_base_asset_to_receive_min_output_quantity is well-implemented, testing a crucial functionality. To further improve the test, consider adding detailed comments explaining the rationale behind the setup and the significance of each assertion, especially in the context of the buy operation and minimum output quantity.


853-1037: The test it_executes_a_swap_between_base_assets_with_external_fee_recipient effectively validates the scenario with an external fee recipient. It would be beneficial to include comments detailing the fee calculation and distribution logic to enhance the test's clarity and maintainability.


1039-1151: The test it_reverts_the_swap_if_there_isnt_enough_buffer_for_buying_target_asset correctly simulates a failure scenario due to insufficient buffer for buying the target asset. Enhancing this test with more detailed comments explaining the setup and expected failure conditions would improve its readability and maintainability.


1153-1237: The test it_reverts_swap_if_no_funds_were_passed effectively validates the contract's input validation mechanism. To improve the test's clarity, consider adding comments that detail the expected behavior when no funds are passed and the significance of the specific error message checked in the assertion.


1239-1329: The test it_reverts_swap_if_multiple_funds_were_passed is crucial for ensuring the contract's input validation works as expected when multiple funds are passed. Adding detailed comments explaining the rationale behind this input validation rule and the expected error message would enhance the test's maintainability.


1331-1432: The test it_reverts_if_user_passes_quantities_equal_to_zero correctly simulates a failure scenario due to invalid input values. To improve the test's clarity and maintainability, consider adding comments that detail the significance of testing for quantities equal to zero and the rationale behind the specific error messages checked.


1434-1517: The test it_reverts_if_user_passes_negative_quantities effectively validates the contract's handling of negative input quantities. Including comments explaining why passing negative quantities should result in a revert and the importance of the specific error message would make the test more informative and maintainable.


1519-1627: The test it_reverts_if_there_arent_enough_orders_to_satisfy_min_quantity is important for ensuring the contract's liquidity checks are functioning correctly. Adding comments to explain the setup, especially how the orders are created to simulate insufficient liquidity, and the rationale behind the expected error message would enhance the test's clarity.


1629-1718: The test it_reverts_if_min_quantity_cannot_be_reached correctly simulates a scenario where the minimum quantity cannot be reached due to liquidity constraints. To improve the test's maintainability, consider adding detailed comments explaining the setup and the significance of the specific error message checked in the assertion.


1721-1823: The test it_reverts_if_market_is_paused effectively validates the contract's behavior when attempting to swap in a paused market. Including comments that detail the process of pausing the market and the rationale behind the expected error message would enhance the test's clarity and maintainability.


1825-1926: The test it_reverts_if_user_doesnt_have_enough_inj_to_pay_for_gas is crucial for ensuring the contract's fee handling works as expected. Adding comments to explain the setup, especially how the user's INJ balance is set to simulate insufficient funds for gas, and the significance of the specific error message would make the test more informative and maintainable.


1928-2017: The test it_reverts_if_target_quantity_is_not_multiple_of_min_quantity_tick_size correctly validates an important input validation rule regarding quantity tick size. To improve the test's clarity, consider adding comments explaining the significance of the minimum quantity tick size and the rationale behind the specific error message checked in the assertion.


2020-2079: The test it_allows_admin_to_withdraw_all_funds_from_contract_to_his_address effectively validates an important administrative function of the contract. Adding comments to explain the setup, especially the initialization of the contract with specific balances, and the significance of each assertion would enhance the test's clarity and maintainability.


2081-2143: The test it_allows_admin_to_withdraw_all_funds_from_contract_to_other_address is well-implemented, testing an important aspect of the contract's administrative functions. To further improve the test, consider adding detailed comments explaining the rationale behind allowing withdrawals to other addresses and the significance of each assertion.


2145-2209: The test it_doesnt_allow_non_admin_to_withdraw_anything_from_contract correctly validates the contract's access control mechanisms. Including comments that detail the setup, especially the distinction between the admin and a non-admin user, and the rationale behind the expected failure would make the test more informative and maintainable.


2211-2233: Utility functions create_eth_buy_orders and create_atom_sell_orders are used to set up test scenarios by creating buy and sell orders, respectively. These functions are well-implemented, but adding comments explaining the parameters (e.g., market_id, OrderSide, and order quantities) would improve readability and maintainability.

Comment on lines 979 to 1129
&trader1,
&trader2,
);
create_realistic_atom_usdt_sell_orders_from_spreadsheet(
&app,
&spot_market_2_id,
&trader1,
&trader2,
&trader3,
);

app.increase_time(1);

let eth_to_swap = "4.08";

let swapper = must_init_account_with_funds(
&app,
&[
str_coin(eth_to_swap, ETH, Decimals::Eighteen),
str_coin("1", INJ, Decimals::Eighteen),
],
);

let query_result: FPDecimal = wasm
.query(
&contr_addr,
&QueryMsg::GetOutputQuantity {
source_denom: ETH.to_string(),
target_denom: ATOM.to_string(),
from_quantity: human_to_dec(eth_to_swap, Decimals::Eighteen),
},
)
.unwrap();

assert_eq!(
query_result,
human_to_dec("906.195", Decimals::Six),
"incorrect swap result estimate returned by query"
);

let contract_balances_before = query_all_bank_balances(&bank, &contr_addr);
assert_eq!(
contract_balances_before.len(),
1,
"wrong number of denoms in contract balances"
);

wasm.execute(
&contr_addr,
&ExecuteMsg::SwapMinOutput {
target_denom: ATOM.to_string(),
min_output_quantity: FPDecimal::from(906u128),
},
&[str_coin(eth_to_swap, ETH, Decimals::Eighteen)],
&swapper,
)
.unwrap();

let from_balance = query_bank_balance(&bank, ETH, swapper.address().as_str());
let to_balance = query_bank_balance(&bank, ATOM, swapper.address().as_str());
assert_eq!(
from_balance,
FPDecimal::ZERO,
"some of the original amount wasn't swapped"
);
assert_eq!(
to_balance,
human_to_dec("906.195", Decimals::Six),
"swapper did not receive expected amount"
);

let contract_balances_after = query_all_bank_balances(&bank, contr_addr.as_str());
assert_eq!(
contract_balances_after.len(),
1,
"wrong number of denoms in contract balances"
);

let atom_amount_below_min_tick_size = FPDecimal::must_from_str("0.0005463");
let mut dust_value = atom_amount_below_min_tick_size * human_to_dec("8.89", Decimals::Six);

let fee_refund = dust_value
* FPDecimal::must_from_str(&format!(
"{}",
DEFAULT_TAKER_FEE * DEFAULT_ATOMIC_MULTIPLIER * DEFAULT_SELF_RELAYING_FEE_PART
));

dust_value += fee_refund;

let expected_contract_usdt_balance =
FPDecimal::must_from_str(contract_balances_before[0].amount.as_str()) + dust_value;
let actual_contract_balance =
FPDecimal::must_from_str(contract_balances_after[0].amount.as_str());
let contract_balance_diff = expected_contract_usdt_balance - actual_contract_balance;

// here the actual difference is 0.000067 USDT, which we attribute differences between decimal precision of Rust/Go and Google Sheets
assert!(
human_to_dec("0.0001", Decimals::Six) - contract_balance_diff > FPDecimal::ZERO,
"contract balance has changed too much after swap"
);
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The ignored test it_correctly_calculates_required_funds_when_querying_buy_with_minimum_buffer_and_realistic_values highlights an important aspect of swap functionality related to fund estimation. While the test is currently ignored, it's essential to address the underlying issue causing the discrepancy in fund estimation. This could involve adjusting the query logic or ensuring that the test setup accurately reflects real-world conditions.

Comment on lines 1141 to 1278
vec![
spot_market_1_id.as_str().into(),
spot_market_2_id.as_str().into(),
],
);

let trader1 = init_rich_account(&app);
let trader2 = init_rich_account(&app);
let trader3 = init_rich_account(&app);

create_realistic_eth_usdt_buy_orders_from_spreadsheet(
&app,
&spot_market_1_id,
&trader1,
&trader2,
);
create_realistic_atom_usdt_sell_orders_from_spreadsheet(
&app,
&spot_market_2_id,
&trader1,
&trader2,
&trader3,
);

app.increase_time(1);

let eth_to_swap = "4.08";

let swapper = must_init_account_with_funds(
&app,
&[
str_coin(eth_to_swap, ETH, Decimals::Eighteen),
str_coin("0.01", INJ, Decimals::Eighteen),
],
);

let contract_balances_before = query_all_bank_balances(&bank, &contr_addr);
assert_eq!(
contract_balances_before.len(),
1,
"wrong number of denoms in contract balances"
);

wasm.execute(
&contr_addr,
&ExecuteMsg::SwapMinOutput {
target_denom: ATOM.to_string(),
min_output_quantity: FPDecimal::from(906u128),
},
&[str_coin(eth_to_swap, ETH, Decimals::Eighteen)],
&swapper,
)
.unwrap();

let from_balance = query_bank_balance(&bank, ETH, swapper.address().as_str());
let to_balance = query_bank_balance(&bank, ATOM, swapper.address().as_str());
assert_eq!(
from_balance,
FPDecimal::ZERO,
"some of the original amount wasn't swapped"
);
assert_eq!(
to_balance,
human_to_dec("906.195", Decimals::Six),
"swapper did not receive expected amount"
);

let contract_balances_after = query_all_bank_balances(&bank, contr_addr.as_str());
assert_eq!(
contract_balances_after.len(),
1,
"wrong number of denoms in contract balances"
);

let contract_usdt_balance_before =
FPDecimal::must_from_str(contract_balances_before[0].amount.as_str());
let contract_usdt_balance_after =
FPDecimal::must_from_str(contract_balances_after[0].amount.as_str());

assert!(
contract_usdt_balance_after >= contract_usdt_balance_before,
"Contract lost some money after swap. Actual balance: {}, previous balance: {}",
contract_usdt_balance_after,
contract_usdt_balance_before
);

// contract can earn max of 0.7 USDT, when exchanging ETH worth ~$8150
let max_diff = human_to_dec("0.7", Decimals::Six);

assert!(
are_fpdecimals_approximately_equal(
contract_usdt_balance_after,
contract_usdt_balance_before,
max_diff,
),
"Contract balance changed too much. Actual balance: {}, previous balance: {}. Max diff: {}",
contract_usdt_balance_after.scaled(Decimals::Six.get_decimals().neg()),
contract_usdt_balance_before.scaled(Decimals::Six.get_decimals().neg()),
max_diff.scaled(Decimals::Six.get_decimals().neg())
);
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Similar to the previous ignored test, it_correctly_calculates_required_funds_when_executing_buy_with_minimum_buffer_and_realistic_values is critical for validating the swap execution with minimal buffer. The discrepancy in required funds estimation needs to be thoroughly investigated and resolved to ensure the swap functionality behaves as expected under tight fund conditions.

@@ -2,7 +2,7 @@
authors = [ "Markus Waas <markus@injectivelabs.org>" ]
edition = "2021"
name = "swap-contract"
version = "1.0.1"
version = "1.0.2"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Version changed, check migration constrains to check if still make sense.

@gorgos gorgos temporarily deployed to github-pages May 13, 2024 08:18 — with GitHub Actions Inactive
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 3

Out of diff range and nitpick comments (4)
README.md (3)

Line range hint 1-24: Clarify documentation on contract instantiation.

The section on contract instantiation is somewhat vague, particularly regarding the version of the contract uploaded to the Injective Mainnet. The phrase "There is version of this contract uploaded to the Injective Mainnet" is missing an article before "version". It should be corrected to "There is a version of this contract uploaded to the Injective Mainnet" for better clarity.


Line range hint 17-24: Improve clarity and conciseness in route setting description.

The description of how routes are set is verbose and could be made more concise. Additionally, the phrase "so that the it knows the route" contains a typographical error and should be corrected to "so that it knows the route".


87-94: Add a comma for better readability.

In the example command under the "Authz Permission" section, consider adding a comma after "Example" for better readability. It should be "Example, how to allow the contract admin to authorize other addresses to make contract calls on their behalf."

.github/workflows/rust.yaml (1)

53-59: Ensure optimal build flags for WASM compilation.

The build flags for compiling WASM contracts have been set to optimize the build. However, it's important to ensure that these flags are indeed producing the optimal build for the specific needs of your project. Consider reviewing these flags periodically to adapt to changes in the project requirements or updates in the toolchain.

Review Details

Configuration used: CodeRabbit UI
Review profile: CHILL

Commits Files that changed from the base of the PR and between a088c23 and b42c285.
Files ignored due to path filters (1)
  • Cargo.lock is excluded by !**/*.lock
Files selected for processing (8)
  • .github/workflows/rust.yaml (1 hunks)
  • Cargo.toml (1 hunks)
  • README.md (1 hunks)
  • contracts/swap/Cargo.toml (3 hunks)
  • contracts/swap/src/contract.rs (1 hunks)
  • contracts/swap/src/testing/authz_tests.rs (1 hunks)
  • contracts/swap/src/testing/mod.rs (1 hunks)
  • contracts/swap/src/testing/test_utils.rs (6 hunks)
Files skipped from review due to trivial changes (4)
  • Cargo.toml
  • contracts/swap/Cargo.toml
  • contracts/swap/src/contract.rs
  • contracts/swap/src/testing/mod.rs
Additional Context Used
LanguageTool (9)
README.md (9)

Near line 7: Possible missing article found.
Context: ...instance of the Swap contract. There is version of this contract uploaded to the Inject...


Near line 17: Replace ‘token’ with an appropriate verb.
Context: ...fined. Route means which markets should token A go through in order to get token B. F...


Near line 17: Consider a shorter alternative to avoid wordiness.
Context: ...which markets should token A go through in order to get token B. For example, if you would ...


Near line 17: Please verify. Did you mean “it” or “the IT” (= information technology)?
Context: ... IDs of ATOM/USDT and INJ/USDT, so that the it knows the route of swapping ATOM and IN...


Near line 18: For conciseness, consider replacing this expression with an adverb.
Context: ... and INJ would be ATOM <> USDT <> INJ. At this moment, the contract can only support markets ...


Near line 23: After ‘it’, use the third-person verb form “places”.
Context: ... buffer is used by the contract when it place orders. If the user wants to swap a big...


Near line 23: The word ‘big’ tends to be overused. Consider an alternative.
Context: ...ace orders. If the user wants to swap a big amount or swap in an illiquid market, then mor...


Near line 24: For conciseness, consider replacing this expression with an adverb.
Context: ...annot satisfy the user's input amount. At this moment, the buffer should only be in USDT. ##...


Near line 88: Possible missing comma found.
Context: ...esult ``` ## Authz Permission Example how to allow the contract admin to auth...

Additional comments not posted (9)
contracts/swap/src/testing/test_utils.rs (9)

1-1: Added import for Scaled from crate::helpers.

This import is necessary for the new functionality introduced in this file.


3-3: Changed import from cosmos_sdk_proto::prost::Message to prost::Message.

This change simplifies the import path and is consistent with Rust best practices for using external crates.


18-36: Reorganized imports for injective_std.

The reorganization improves readability and maintainability by grouping related imports together.


37-39: Reorganized imports for injective_test_tube.

Similar to the previous comment, this change enhances the structure and clarity of the import statements.


40-40: Added imports for HashMap and FromStr.

These imports are necessary for the new functionality related to handling collections and parsing strings.


316-331: Modified wasm_file function to handle different architectures and directories.

This modification increases the flexibility and robustness of the function, allowing it to adapt to different build environments and directory structures.


756-756: Added cid parameter to OrderInfo in create_limit_order.

This addition is necessary for the new functionality related to contract interaction, allowing unique identifiers for orders.


819-819: Added cid parameter to OrderInfo in create_realistic_limit_order.

Consistent with the previous change, this addition supports new features related to order management in the testing environment.


961-1021: Added create_contract_authorization function.

This new function enhances the testing capabilities by allowing the simulation of contract authorization scenarios, which is crucial for comprehensive contract testing.

Comment on lines +16 to +45
#[test]
pub fn set_route_for_third_party_test() {
let app = InjectiveTestApp::new();
let wasm = Wasm::new(&app);
let authz = Authz::new(&app);
let exchange = Exchange::new(&app);

let owner = must_init_account_with_funds(
&app,
&[
str_coin("1", ETH, Decimals::Eighteen),
str_coin("1", ATOM, Decimals::Six),
str_coin("1_000", USDT, Decimals::Six),
str_coin("10_000", INJ, Decimals::Eighteen),
],
);

let spot_market_1_id = launch_realistic_weth_usdt_spot_market(&exchange, &owner);
let spot_market_2_id = launch_realistic_atom_usdt_spot_market(&exchange, &owner);

let contr_addr = init_self_relaying_contract_and_get_address(
&wasm,
&owner,
&[str_coin("1_000", USDT, Decimals::Six)],
);

let trader1 = init_rich_account(&app);
let trader2 = init_rich_account(&app);
let trader3 = init_rich_account(&app);

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ensure proper cleanup and resource management in tests.

While the test function set_route_for_third_party_test initializes several accounts and contracts, it does not explicitly clean up or release resources after the test execution. This might lead to resource leakage or conflicts in subsequent tests. Consider adding teardown steps or using context managers to ensure resources are properly cleaned up.

Comment on lines +46 to +68
create_contract_authorization(
&app,
contr_addr.clone(),
&owner,
trader1.address().to_string(),
"set_route".to_string(),
1,
None,
);

create_realistic_eth_usdt_buy_orders_from_spreadsheet(
&app,
&spot_market_1_id,
&trader1,
&trader2,
);
create_realistic_atom_usdt_sell_orders_from_spreadsheet(
&app,
&spot_market_2_id,
&trader1,
&trader2,
&trader3,
);
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Refactor to improve readability and maintainability.

The segments handling authorization and order creation are quite verbose and involve repeated code, especially in the handling of trader accounts and market setups. Consider refactoring these into helper functions or using loops to handle repetitive tasks, which would improve both readability and maintainability.

Comment on lines +72 to +112
let set_route_msg = ExecuteMsg::SetRoute {
source_denom: ETH.to_string(),
target_denom: ATOM.to_string(),
route: vec![
spot_market_1_id.as_str().into(),
spot_market_2_id.as_str().into(),
],
};

let execute_msg = MsgExecuteContract {
contract: contr_addr.clone(),
sender: owner.address().to_string(),
msg: serde_json_wasm::to_vec(&set_route_msg).unwrap(),
funds: vec![],
};

// execute on more time to excercise account sequence
let msg = MsgExec {
grantee: trader1.address().to_string(),
msgs: vec![Any {
type_url: "/cosmwasm.wasm.v1.MsgExecuteContract".to_string(),
value: execute_msg.to_bytes().unwrap(),
}],
};

let _res = authz.exec(msg, &trader1).unwrap();

// execute on more time to excercise account sequence
let msg = MsgExec {
grantee: trader1.address().to_string(),
msgs: vec![Any {
type_url: "/cosmwasm.wasm.v1.MsgExecuteContract".to_string(),
value: execute_msg.to_bytes().unwrap(),
}],
};

let err = authz.exec(msg, &trader1).unwrap_err();
assert!(
err.to_string().contains("failed to update grant with key"),
"incorrect error returned by execute"
);
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add error handling for JSON serialization.

The test function uses serde_json_wasm::to_vec(&set_route_msg).unwrap() for JSON serialization without handling potential serialization errors. This could cause the test to panic if serialization fails. It's recommended to handle these errors gracefully to avoid test crashes and to provide more informative error messages.

@gorgos gorgos temporarily deployed to github-pages May 13, 2024 15:36 — with GitHub Actions Inactive
@gorgos gorgos merged commit bf8dad9 into master May 13, 2024
2 checks passed
@gorgos gorgos deleted the MITO-62 branch May 13, 2024 15:37
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants