Skip to content

Commit

Permalink
Merge pull request #146 from argentlabs/experiment/migrate-to-truffle
Browse files Browse the repository at this point in the history
Мigrate to truffle
  • Loading branch information
elenadimitrova committed Nov 30, 2020
2 parents 527b1a9 + 9fd72d7 commit 9f1f8ed
Show file tree
Hide file tree
Showing 87 changed files with 17,374 additions and 15,848 deletions.
32 changes: 27 additions & 5 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,12 @@ step_setup_global_packages: &step_setup_global_packages
name: "Set up global packages"
command: |
npm install
step_pull_solc_docker: &step_pull_solc_docker
run:
name: "Pull solc docker images"
command: |
docker pull ethereum/solc:0.5.4
docker pull ethereum/solc:0.6.12
step_setup_slither: &step_setup_slither
run:
name: "Setup slither analyser https://github.com/crytic/slither"
Expand All @@ -46,13 +52,16 @@ jobs:
steps:
- checkout
- <<: *step_restore_cache
- setup_remote_docker:
version: 19.03.13
- <<: *step_pull_solc_docker
- <<: *step_setup_global_packages
- run:
name: "Lint JavaScript"
command: npm run lint:js
- run:
name: "Lint Solidity contracts"
command: npm run lint:contracts
- run:
name: "Testing deployment scripts and benchmark gas costs"
command: npm run ganache >/dev/null 2>&1 & npm run test:deployment && npm run test:benchmark
- run:
name: "Compiling external library contracts"
command: npm run compile:lib
Expand All @@ -66,11 +75,20 @@ jobs:
name: "Compiling test contracts"
command: npm run compile:test
- run:
name: "Lint JavaScript"
command: npm run lint:js
name: "Provision lib artefacts"
command: npm run provision:lib:artefacts
- run:
name: "Test deployment scripts"
command: npm run ganache >/dev/null 2>&1 & npm run test:deployment
no_output_timeout: 60m
- run:
name: "Running unit tests"
command: npm run ganache >/dev/null 2>&1 & npm run test
# Save coverage artifacts
- store_artifacts:
path: gas-usage-report.log
destination: reports/gas-usage-report.log
- run: npx codechecks
- run:
name: "Running coverage"
command: |
Expand All @@ -81,11 +99,15 @@ jobs:
# Save coverage artifacts
- store_artifacts:
path: coverage
destination: coverage-artifacts
security-test:
<<: *job_python
steps:
- checkout
- <<: *step_restore_cache
- setup_remote_docker:
version: 19.03.13
- <<: *step_pull_solc_docker
- <<: *step_setup_global_packages
- <<: *step_setup_slither
- <<: *step_setup_solc_select
Expand Down
3 changes: 2 additions & 1 deletion .eslintignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,4 +4,5 @@ build/*
contracts/*
contracts-test/*
coverage/*
lib/*
lib/*
scripts/coverage.js
9 changes: 8 additions & 1 deletion .eslintrc
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,14 @@
"no-underscore-dangle": "off",
"no-await-in-loop": "off",
"no-restricted-syntax": "off",
"guard-for-in": "off"
"guard-for-in": "off",
"function-paren-newline": "off",
"comma-dangle": "off",
"object-curly-newline": "off",
"no-unused-expressions": "off",
"import/no-extraneous-dependencies": "off",
"import/no-unresolved": "off"

},
"parserOptions": {
"ecmaVersion": 2018
Expand Down
11 changes: 6 additions & 5 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ build-legacy
tmp
bin
.outputParameter
flatten

## Core latex/pdflatex auxiliary files:
*.aux
Expand All @@ -28,17 +29,17 @@ bin

.env
utils/config/*.json
!utils/config/ganache.json
!utils/config/development.json
!utils/config/kovan.json
!utils/config/kovan-fork.json
ganache-accounts.json

## Etherlime
**/.etherlime-store
flat
## solidity-coverage
.coverage_artifacts
.coverage_contracts
.coverage_tests
coverage
coverage.json

crytic-export
crytic-export
gas-usage-report.log
15 changes: 15 additions & 0 deletions .solcover.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
module.exports = {
client: require('ganache-cli'),
skipFiles: [
"../contracts-test",
"../contracts-legacy",
"../lib"
],
providerOptions: {
port: 8555,
_chainId: 1895,
network_id: 1597649375983,
account_keys_path: "./ganache-accounts.json",
default_balance_ether: 10000
}
};
2 changes: 2 additions & 0 deletions codechecks.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
checks:
- name: eth-gas-reporter/codechecks
19 changes: 19 additions & 0 deletions contracts-test/TestOwnedContract.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
// SPDX-License-Identifier: GPL-3.0-only
pragma solidity ^0.6.12;
import "../contracts/infrastructure/base/Owned.sol";

/**
* @title TestOwnedContract
* @notice Represents an arbitrary contract implementing Owned.
*/
contract TestOwnedContract is Owned {

uint256 public state;

event StateSet(uint256 indexed _state, uint256 indexed _value);

function setStateRestricted(uint256 _state) public onlyOwner payable {
state = _state;
emit StateSet(_state, msg.value);
}
}
2 changes: 1 addition & 1 deletion contracts/infrastructure/DexRegistry.sol
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
pragma solidity ^0.6.12;
pragma experimental ABIEncoderV2;

import "../infrastructure/base/Owned.sol";
import "./base/Owned.sol";
import "./IDexRegistry.sol";

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,11 @@
pragma solidity ^0.6.12;
pragma experimental ABIEncoderV2;

import "../common/Utils.sol";
import "../common/LimitUtils.sol";
import "../common/BaseTransfer.sol";
import "../../infrastructure/storage/ILimitStorage.sol";
import "../../infrastructure/storage/IGuardianStorage.sol";
import "./common/Utils.sol";
import "./common/LimitUtils.sol";
import "./common/BaseTransfer.sol";
import "../infrastructure/storage/ILimitStorage.sol";
import "../infrastructure/storage/IGuardianStorage.sol";

/**
* @title ApprovedTransfer
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,13 @@
pragma solidity ^0.6.12;
pragma experimental ABIEncoderV2;

import "../common/Utils.sol";
import "../common/BaseFeature.sol";
import "../common/GuardianUtils.sol";
import "../common/LimitUtils.sol";
import "../../infrastructure/storage/ILimitStorage.sol";
import "../../infrastructure/ITokenPriceRegistry.sol";
import "../../infrastructure/storage/IGuardianStorage.sol";
import "./common/Utils.sol";
import "./common/BaseFeature.sol";
import "./common/GuardianUtils.sol";
import "./common/LimitUtils.sol";
import "../infrastructure/storage/ILimitStorage.sol";
import "../infrastructure/ITokenPriceRegistry.sol";
import "../infrastructure/storage/IGuardianStorage.sol";

/**
* @title RelayerManager
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,11 @@
pragma solidity ^0.6.12;
pragma experimental ABIEncoderV2;

import "../common/BaseFeature.sol";
import "../../../lib/other/ERC20.sol";
import "../../../lib/paraswap/IAugustusSwapper.sol";
import "../../infrastructure/ITokenPriceRegistry.sol";
import "../../infrastructure/IDexRegistry.sol";
import "./common/BaseFeature.sol";
import "../../lib/other/ERC20.sol";
import "../../lib/paraswap/IAugustusSwapper.sol";
import "../infrastructure/ITokenPriceRegistry.sol";
import "../infrastructure/IDexRegistry.sol";

/**
* @title TokenExchanger
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,13 @@
pragma solidity ^0.6.12;
pragma experimental ABIEncoderV2;

import "../common/Utils.sol";
import "../common/BaseTransfer.sol";
import "../common/LimitUtils.sol";
import "../../infrastructure/storage/ILimitStorage.sol";
import "../../infrastructure/storage/ITransferStorage.sol";
import "../../infrastructure/ITokenPriceRegistry.sol";
import "../../../lib/other/ERC20.sol";
import "./common/Utils.sol";
import "./common/BaseTransfer.sol";
import "./common/LimitUtils.sol";
import "../infrastructure/storage/ILimitStorage.sol";
import "../infrastructure/storage/ITransferStorage.sol";
import "../infrastructure/ITokenPriceRegistry.sol";
import "../../lib/other/ERC20.sol";

/**
* @title TransferManager
Expand Down
39 changes: 39 additions & 0 deletions deployment/0_limited_test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
/* global artifacts */
global.web3 = web3;
const chai = require("chai");
const BN = require("bn.js");
const bnChai = require("bn-chai");

const { expect } = chai;
chai.use(bnChai(BN));

const TestOwnedContract = artifacts.require("TestOwnedContract");
const MultiSig = artifacts.require("MultiSigWallet");

const deployManager = require("../utils/deploy-manager.js");
const MultisigExecutor = require("../utils/multisigexecutor.js");

async function main() {
const { deploymentAccount, configurator } = await deployManager.getProps();
console.log("deploymentAccount", deploymentAccount);
const { config } = configurator;

const testContractWrapper = await TestOwnedContract.new();
console.log("TestOwnedContract created at", testContractWrapper.address);

await testContractWrapper.changeOwner(config.contracts.MultiSigWallet);
console.log("Set the MultiSig as the owner of TestOwnedContract");

const MultiSigWrapper = await MultiSig.at(config.contracts.MultiSigWallet);
const multisigExecutor = new MultisigExecutor(MultiSigWrapper, deploymentAccount, config.multisig.autosign);
await multisigExecutor.executeCall(testContractWrapper, "setStateRestricted", [99]);
const stateValue = await testContractWrapper.state();
expect(stateValue).to.eq.BN(99);

console.log("## completed deployment script 7 ##");
}

// For truffle exec
module.exports = function (callback) {
main().then(() => callback()).catch((err) => callback(err));
};
Loading

0 comments on commit 9f1f8ed

Please sign in to comment.