-
Notifications
You must be signed in to change notification settings - Fork 10
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
Release/1.0.0 beta #96
Merged
Merged
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
* chore: update .solhintignore to exclude contracts/mocks directory * lint fix * test: add test for AccountFactory deployment consistency * chore: Add test for ERC4337Account deposit balance consistency * invariant test for ERC4337Account ValidateUserOp invariant * add TestInvariant_ModuleManager to test module management functionality * test: add fuzz test for AccountFactory deployment * chore: Add fuzz tests for ERC4337Account and ModuleManager * Lint fix SmartAccountTestLab.t.sol for readability * chore: Refactor test setup for Foundry invariant testing * chore: Add InvariantModuleManagementHandler for module installation and uninstallation tests * chore: Update solhint npm dependency to version 5.0.0 * Update solhint npm dependency to version 5.0.0 * Add ExecutionInvariantTests contract for testing execution-related invariants * Add AccountInvariantTests contract for testing account creation invariants * chore: Add InvariantModuleManagementHandler for module installation and uninstallation tests * chore: Add InvariantExecutionHandler for testing execution-related invariants * chore: Add InvariantDepositManagementHandler for testing deposit-related invariants * feat: Add InvariantAccountCreationHandler for testing account creation invariants * Add BaseInvariantTest contract for foundational test setup * chore: Add TestInvariantNexus contract for testing invariant consistency * Add TestInvariantExecutor contract for testing invariant execution * Add TestInvariantExecutionHelper contract for testing authorized executor invariants * feat: Add TestInvariantBaseAccount contract for testing base account invariants * chore: Refactor TestInvariant_ModuleManager.t.sol for improved readability and consistency * feat: Refactor TestInvariant_ERC4337Account_ValidateUserOp for improved readability and consistency * chore: Add ActorManager contract for coordinating test actions across different actors * feat: Refactor TestInvariant_AccountFactory_Deployment.t.sol for improved readability and consistency * Refactor TestInvariant_ERC4337Account_DepositBalance.t.sol for improved readability and consistency * Import IExecutor and MockToken contracts for testing * 🔥 remove unused test files * 🔥 Remove unused test files * Refactor test files for improved readability and consistency * Add Tests + Invariants + Refactor test files for improved readability and consistency * BaseInvariantTest.t.sol for improved testing * ✅ add Handlers for Invariantstest files * ✅ Add ActorManager for invariant testing * chore: Update solhint dependency to version 5.0.1 * 🔥 remove unused tests * Refactor ActorManager test file * Refactor AccountCreationHandler test file * Add fuzz testing on TestFuzz_ValidateUserOp contract * feat: Add TestFuzz_ExecuteFromExecutor contract for fuzz testing * chore: Exclude VALIDATOR_MODULE in AccountValidateUserOpInvariantTests setup * refactor: Improve test file structure and naming conventions * refactor: Update TestAccountFactory_CreateAndGetCounterFactualAddress.t.sol * refactor: Add fuzz testing for ERC4337Account withdrawal and signature validation * refactor: Add execute fuzz testing with mocks * ✅ add fuzz testing on module manager + edge cases * ✅ add new Uninstall test cases * refactor: Improve isContract function in Helpers.sol and testFuzz_TokenTransfer in TestFuzz_Execute.t.sol * refactor: Fix formatting * 🖼️ fix lint + reorder * 📄 update Natspec security message * refactor: Fix module msg installation test case * chore: Update .solcover.js to skip "contracts/mocks" file in code coverage * chore: Add hardhat-foundry plugin for Nexus project * chore: Update post-checkout hook to include forge install command * chore: Update comment.js to include details in a collapsible section * chore: Update slither-action to v0.4.0 and node-version to 20 * Rename variable to remove shadowed var * 🔥 remove unused variables in Nexus.sol * chore: Add defender.config.json for contract inspector configuration * ⚙️Update slither-action to exclude additional checks in ci.yml * 🚀 gas optimization: Improve execution mode decoding in Nexus.sol * 🔥 Remove unused delegate functions in ExecutionHelper.sol * chore: Update BaseAccount.sol header comments * Update ModuleManager.sol slither fix * Add check for non-zero address slither fix * chore: Add error handling for zero implementation address * Add IValidator interface to K1Validator contract - slither fix * use assertTrue for balance check * lint fix * add tests validate user operation from entry point * add accesscontrol+unauthorized access tests * refactor: add InvalidSignature error to EventsAndErrors.sol * add tests cases + fix wrong asserts * chore: Update deployment account funding amount in test * Remove unnecessary code in TestERC4337Account_ValidateUserOp.t.sol * add test for validation of user operation nonce * Merge branch 'dev' of https://github.com/bcnmy/erc7579-modular-smart-account into dev * 🖼️ Refactor project architecture / and rename files * chore: Remove unused functions, improve comments and formatting in CheatCodes.sol * chore: Update account balance initialization with default method * chore: Update contract deployment and account labeling in Helpers.sol with default method * Renamed preparePackedUserOperation to buildPackedUserOperation for consistancy * Refactor project architecture and rename functions * Update function name from preparePackedUserOperation to buildPackedUserOperation for consistency * move functions to helpers * Refactor helpers and rename functions * chore: Refactor code and update function names for consistency * Refactor NexusTest contract and update function names for consistency * Refactor NexusTest contract and update function names for consistency * Refactor Imports.sol and update import statement for TestHelper.t.sol * Refactor SmartAccountTestLab contract and remove unused code * Refactor imports and update test contracts for consistency * Refactor NexusTest_Base contract and remove unused code * Refactor code and remove unused imports and functions * ✅ fix solc warning compiler * ✅ Refactor code add negative tests * chore: Refactor code and update function names for consistency * Refactor code and add prefunding for smart account in TestFuzz_ValidateUserOp.t.sol * Refactor code and remove inline comments * Refactor code and improve inline comments * Refactor code and improve inline comments add additional tests * Refactor code, add natspecs, and improve inline comments in InvariantBaseTest contract * Refactor AccountCreationHandlerTest contract, improve comments, and add validation for account creation * Refactor DepositManagementHandlerTest contract, improve comments, and update Solidity version to ^0.8.0 * feat: Add ExecutionHandlerTest contract for executing operations on Nexus account and add natspec * add natspecs * feat: Add test for AccountDepositBalanceInvariantTest * refactor: Improve comments and update Solidity version in AccountValidateUserOpInvariantTest * chore: Update BaseAccountInvariantTest with natspec comments and improve code readability * chore: Refactor ExecutorInvariantTest for improved code readability and maintainability * refactor: Improve comments and update natspec in ModuleManagerInvariantTest * refactor: Improve comments and update natspec in NexusInvariantTest * refactor: Update TestAccountExecution_Base contract with natspec comments and improve code readability * refactor: Update TestModuleManagement_Base contract with natspec comments and improve code readability * refactor: Improve comments and update natspec in TestAccountConfig_AccountId.t.sol * refactor: Improve comments and update natspec in TestAccountConfig_SupportsExecutionMode.t.sol * refactor: Improve comments and update natspec in TestAccountExecution_TryExecuteSingle.t.sol * refactor: Improve comments and update natspec * renamed file * refactor: Add missing events and update natspec * refactor: Update Solidity version to 0.8.24 in multiple files * refactor: improve and categorize events and errors * add check on onUninstall hook * fix test on invariants and fuzz * fix test on invariants and fuzz * fix invariant by adding check for installed module in onInstall function * refactor: Skip precompiles in testFuzz_WithdrawDepositTo function * fix warning and remove unused variables * remove empty file * add accountImplementationAddress test on ArbitrumSmartAccountUpgradeTest * refactor: Add getImplementation function to IBiconomySmartAccountV2 interface * refactor: Add UpgradeSmartAccountTest to test smart account implementation upgrade * refactor: Rename tests * refactor: Improve UpgradeSmartAccountTest with additional tests * refactor: Exclude FACTORY contract from BaseAccountInvariantTest * refactor: Exclude unnecessary contracts from AccountDepositBalanceInvariantTest setup * fix invariant by ensuring signer has enough ether before adding deposit * Renamed .t.sol test files + Exclude unnecessary contracts from NexusInvariantTest setup * refactor: Add givenTheAccountConfiguration modifier to TestAccountConfig_AccountId * add .tree to comply with BTT testing * Update Solidity version to >=0.8.0 <0.9.0 * Chore/remove unused funcs (#77) * refactor: Remove onlyValidatorModule modifier from ModuleManager.sol * refactor: Add test cases for unsupported call types in TestAccountExecution_ExecuteSingle * refactor: Update MockExecutor to support tryExecuteViaAccount and customExecuteViaAccount methods * feat: Add MockInvalidModule contract for testing purposes * refactor: Update MockExecutor to support tryExecuteViaAccount and customExecuteViaAccount methods * refactor: Update TestAccountExecution_ExecuteFromExecutor.tree with descriptive test cases * refactor: Update TestAccountExecution_ExecuteSingle.t.sol with more descriptive test cases * refactor: Update TestAccountExecution_ExecuteSingle.tree with descriptive test cases for unsupported call types * refactor: Add test case for installing a module as an invalid module type ID * refactor: Add test case for installing a module with an invalid module type ID * refactor: Update Imports.sol to import MockInvalidModule for testing purposes * refactor: Update EventsAndErrors.sol to add error messages for unsupported module and call types * Improve Natspecs in invariants *⚠️ fix compiler warning *⚠️ fix compilers / lint warnings * 🖼️ lint fix * chore: Update foundry-gas-diff workflow to continue on error * chore: Skip posting comment if Slither report is empty * chore: add warning comment on privatekey * chore: Update CI workflow to include ARBITRUM_RPC_URL environment variable * chore: Update ArbitrumSmartAccountUpgradeTest to use environment variable for RPC URL * chore: Update ArbitrumSettings with default Arbitrum RPC URL --------- Co-authored-by: livingrockrises <90545960+livingrockrises@users.noreply.github.com>
…tests with K1 factory
…getting init nexus calldata
… BOOTSTRAPPER.getInitNexusScopedCalldata function
…getting init nexus calldata
…-slots check and update two slots
feat: hardhat tests
Feat/fallback selector security check
Feat/forge test coverage
* feat: Add AbstractNexusFactory contract This commit adds the `AbstractNexusFactory` contract, which provides common functionality for Nexus factories. It enables the creation and management of Modular Smart Accounts. The contract includes a constructor to set the smart account implementation address and the factory owner. It also includes functions to create a new Nexus with initialization data and compute the expected address of a Nexus contract using the factory's deterministic deployment algorithm. * Refactor the Nexus contract to improve code readability and maintainability. Also, fix the revert message from "EntryPointCannotBeZero" to "EntryPointCanNotBeZero" for consistency. * feat: Whitelist factory address in BiconomyMetaFactory This commit adds functionality to whitelist factory addresses in the BiconomyMetaFactory contract. It ensures that only whitelisted factories can be used for deployment. Additionally, it includes error handling for invalid factory addresses and zero owner addresses in the constructor. * feat: Improve K1ValidatorFactory contract This commit improves the K1ValidatorFactory contract by making the following changes: - Renaming the contract to "K1ValidatorFactory for Nexus Account" for clarity. - Removing the dependency on the BootstrapUtil library and updating the import statement accordingly. - Adding error handling for zero addresses in the constructor. - Refactoring the createAccount function to compute the actual salt for deterministic deployment. - Using the BootstrapLib library to create the validator configuration. - Initializing the account only if it was not already deployed. - Updating the computeAccountAddress function to compute the actual salt for deterministic deployment. - Predicting the deterministic address using the LibClone library. These changes enhance the readability, maintainability, and functionality of the K1ValidatorFactory contract. * feat: Improve K1ValidatorFactory contract * feat: Refactor NexusAccountFactory contract for improved readability and maintainability This commit refactors the NexusAccountFactory contract to enhance its readability and maintainability. The following changes were made: - Renamed the contract to "Nexus Account Factory" for clarity. - Removed unnecessary comments and unused imports. - Inherited from the AbstractNexusFactory contract to leverage common functionality. - Updated the constructor to set the smart account implementation address and owner using the AbstractNexusFactory constructor. - Updated the createAccount function to compute the actual salt for deterministic deployment. - Removed the unused computeAccountAddress function. - Improved code formatting and documentation. These changes improve the overall quality and maintainability of the NexusAccountFactory contract. * feat: Fix typo in INexus contract error message * feat: Add IAbstractNexusFactory interface This commit adds the `IAbstractNexusFactory` interface, which defines the essential structure for Nexus factories. It includes functions to create a new Nexus with initialization data and compute the expected address of a Nexus contract using the factory's deterministic deployment algorithm. The interface also includes events and error handling for the creation of Smart Accounts. * feat: Add BootstrapLib library for creating and managing BootstrapConfig structures This commit adds the `BootstrapLib` library, which provides utility functions for creating and managing `BootstrapConfig` structures. The library includes functions to create a single `BootstrapConfig` structure, an array with a single `BootstrapConfig` structure, and an array of `BootstrapConfig` structures. These functions allow for easy configuration of modules and their initialization data. The library enhances the readability and maintainability of the code by providing a standardized way to create and manage `BootstrapConfig` structures. * feat: Refactor NexusAccountFactory contract for improved readability and maintainability * refactor: Update NexusAccountUpgradeTest contract to use BootstrapLib for creating BootstrapConfig structures This commit updates the NexusAccountUpgradeTest contract to utilize the newly added BootstrapLib library for creating and managing BootstrapConfig structures. By using the library's utility functions, the code becomes more readable and maintainable. This change enhances the overall quality of the contract and improves the developer experience. * lint fix * refactor: Remove unused code in UpgradeSmartAccountTest.t.sol * refactor: Rename variable in TestStakeable contract for clarity This commit renames the variable `stakeable` to `_stakeable` in the TestStakeable contract. The new name provides better clarity and improves the readability of the code. * feat: Add TestBiconomyMetaFactory_Deployments contract for managing factory whitelist and deploying accounts This commit adds the TestBiconomyMetaFactory_Deployments contract, which is responsible for managing the factory whitelist and deploying accounts using the BiconomyMetaFactory. The contract includes functions to add and remove factories from the whitelist, deploy accounts using whitelisted factories, and validate factory addresses. Additionally, it tests various scenarios related to factory whitelisting and account deployment. This new contract enhances the functionality and flexibility of the system. * feat: Add TestK1ValidatorFactory_Deployments contract for deploying accounts using the K1ValidatorFactory This commit adds the TestK1ValidatorFactory_Deployments contract, which is responsible for deploying accounts using the K1ValidatorFactory. The contract includes functions to set up the testing environment, test the constructor's functionality, and validate the deployment of accounts. This new contract enhances the testing capabilities and ensures the correct deployment of accounts using the K1ValidatorFactory. * feat: Add TestK1ValidatorFactory_Deployments contract for deploying accounts using the K1ValidatorFactory * feat: Add TestK1ValidatorFactory_Deployments contract for deploying accounts using the K1ValidatorFactory * rename lib * refactor: add error message in EventsAndErrors.sol + new imports * fix fuzz test for account factory * feat: Add input validation for random function selector in fuzz test * refactor: Rename BootstrapUtil to BootstrapLib for clarity * add libraries and fixed tests * feat: Add Nexus contracts for Modular Smart Account compliance This commit adds the Nexus contracts for Modular Smart Account compliance. These contracts are developed by Biconomy and are compliant with ERC-7579 and ERC-4337. The Nexus contracts provide a suite of contracts for creating modular smart accounts. They include the AbstractNexusFactory, ModuleWhitelistFactory, and NexusAccountFactory contracts. These contracts enhance the functionality and flexibility of the system. Learn more at https://biconomy.io. * refactor: Add error message in EventsAndErrors.sol * refactor: Organize imports in Imports.sol * refactor: Backup current gas report before generating a new one * refactor: current gas report before generating a new one * refactor: Backup current gas report before generating a new one * refactor: Update gas report generation process and file names * Feat/missing coverage (#93) * refactor: Add unit tests for TestAccountExecution_ExecuteUserOp contract * refactor: Update gas report generation process and file names * refactor: Improve executeUserOp function in Nexus.sol * refactor: Remove errors in INexus.sol * refactor: moved Nexus Errors / Events to INexusEventsAndErrors.sol * remove compiler warnings * refactor and improve style of tests and namings * refactor: Improve executeUserOp function and comments in Nexus.sol * refactor: Remove original lcov.info and coverage.json files * refactor: Add codecov configuration file * Remove gas logging + fix pr comment * refactor: Improve test coverage and naming conventions * refactor: Update codecov configuration to ignore scripts and test directories
* remove todo * Add natspec + inline comments + description * feat: Refactor test tree descriptions for improved readability and clarity * fix natspecs+ Refactor NexusAccountFactory constructor parameter names * update report * feat: Refactor codecov.yml * feat: Fix uninitialized variable in Nexus.sol * feat: Refactor NexusAccountFactory contract for improved readability and maintainability * Refactor NexusAccountFactory contract for improved readability and maintainability
* chore: Update solc version to 0.8.26 * chore: Update solc version to 0.8.26 * chore: Update solc version to 0.8.26 * chore: Update solc version to 0.8.26 * refactor: Change external functions to internal in TestNexusERC721Integration contract * refactor: Change function visibility from external to internal in TestHelper contract * chore: Update npm dependencies to latest versions * chore: Update solidity version to 0.8.26 with viaIR optimization * chore: Update solidity version to 0.8.26 with viaIR optimization * lint fix * refactor: Update coverage script to use --ir-minimum flag * refactor: Update coverage script to use --ir-minimum flag * refactor: Update coverage script to use --ir-minimum flag * chore: Update CI workflow to include git pull before committing gas report changes * chore: Update CI workflow to include git pull before committing gas report changes * refactor: Update coverage script to remove --ir-minimum flag * chore: Update CI workflow to work on pr only * feat: Update ModuleWhitelistFactory to use isModuleWhitelisted instead of isWhitelisted The commit updates the ModuleWhitelistFactory contract to use the isModuleWhitelisted function instead of the deprecated isWhitelisted function. This change ensures that all modules are properly whitelisted before execution. * push new gas report * feat: Update solidity version to 0.8.26 in AbstractNexusFactory.sol * Update solidity version to 0.8.26 in AbstractNexusFactory.sol * feat: Update solidity version to 0.8.26 in BootstrapLib.sol * feat: Add error messages for new events in EventsAndErrors.sol * feat: Update TestBiconomyMetaFactory_Deployments contract to handle revert message change * refactor: Update NexusAccountFactory contract for improved readability and maintainability * refactor: Restrict fallback handler manipulation in ModuleManager.sol The commit restricts the manipulation of the fallback handler in the ModuleManager contract to ensure the account's security and integrity. It prevents unauthorized uninstallation and reinstallation of the validator module, which could compromise the account's security. Additionally, it checks for the presence of an existing fallback handler to avoid overwriting it and causing unexpected behavior. * feat: Add error handling for invalid EntryPoint address The commit adds error handling for an invalid EntryPoint address in the Stakeable contract. This ensures that only valid addresses can be used when adding, unlocking, or withdrawing stakes. * refactor: Update AbstractNexusFactory constructor to use require instead of revert The commit updates the constructor of the AbstractNexusFactory contract to use the require statement instead of revert. This change improves code readability and follows best practices for error handling. * refactor: Update BiconomyMetaFactory constructor to use require instead of revert The commit updates the constructor of the BiconomyMetaFactory contract to use the require statement instead of revert. This change improves code readability and follows best practices for error handling. * refactor: Use require instead of revert in ModuleWhitelistFactory constructor and addModuleToWhitelist function The commit updates the constructor of the ModuleWhitelistFactory contract to use the require statement instead of revert. This change improves code readability and follows best practices for error handling. It also updates the addModuleToWhitelist function to use require instead of revert. This ensures that the module address being added to the whitelist is not a zero address. Refactor the ModuleWhitelistFactory contract to improve code readability and maintainability. * refactor: Update Stakeable contract error handling for invalid EntryPoint address * remove natspec * refactor: Add InnerCallFailed error to INexusEventsAndErrors.sol The commit adds the InnerCallFailed error to the INexusEventsAndErrors.sol interface. This error is thrown when an inner call fails. This addition enhances the error handling capabilities of the interface. Refactor the INexusEventsAndErrors.sol interface to include the InnerCallFailed error. * refactor: Use require instead of revert in K1ValidatorFactory constructor The commit updates the constructor of the K1ValidatorFactory contract to use the require statement instead of revert. This change improves code readability and follows best practices for error handling. * Update GAS_REPORT.md and gas_report.json * lint fix * lint fix * refactor: Update Stakeable contract error handling for invalid EntryPoint address
Release/1.0.0 beta
🚨 Report Summary
For more details view the full report in OpenZeppelin Code Inspector |
ankurdubey521
approved these changes
Jun 4, 2024
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
No description provided.