clean up truffle-config and enable optimiser;

update test to mock token
This commit is contained in:
Lecky Lao 2020-07-09 21:33:21 +10:00
parent 3bb6ab8a52
commit e76db40294
4 changed files with 34 additions and 89 deletions

View File

@ -1,12 +1,10 @@
const CurveProtocol = artifacts.require("CurveProtocol"); // const CurveProtocol = artifacts.require("CurveProtocol");
const ConnectSBTCCurve = artifacts.require("ConnectSBTCCurve"); // const ConnectSBTCCurve = artifacts.require("ConnectSBTCCurve");
const MockContract = artifacts.require("MockContract");
const connectorsABI = require("../test/abi/connectors.json");
let connectorsAddr = "0xD6A602C01a023B98Ecfb29Df02FBA380d3B21E0c";
let connectorInstance = new web3.eth.Contract(connectorsABI, connectorsAddr);
module.exports = async function(deployer) { module.exports = async function(deployer) {
deployer.deploy(CurveProtocol); // deployer.deploy(CurveProtocol);
let connectorLength = await connectorInstance.methods.connectorLength().call(); deployer.deploy(MockContract);
deployer.deploy(ConnectSBTCCurve, 1, +connectorLength + 1); // let connectorLength = await connectorInstance.methods.connectorLength().call();
// deployer.deploy(ConnectSBTCCurve, 1, +connectorLength + 1);
}; };

View File

@ -6,23 +6,26 @@ const {
ether ether
} = require('@openzeppelin/test-helpers'); } = require('@openzeppelin/test-helpers');
const MockContract = artifacts.require("MockContract.sol") const MockContract = artifacts.require("MockContract");
const ConnectSynthetixStaking = artifacts.require('ConnectSynthetixStaking'); const ConnectSynthetixStaking = artifacts.require('ConnectSynthetixStaking');
const erc20ABI = require("./abi/erc20.js"); const erc20ABI = require("./abi/erc20.js");
contract('ConnectSynthetixStaking', async accounts => { contract('ConnectSynthetixStaking', async accounts => {
const [sender, receiver] = accounts; const [sender, receiver] = accounts;
const mock = await MockContract.new();
const crvRenWSBTCContract = new web3.eth.Contract(erc20ABI, mock.address);
before(async function () { before(async function () {
const mock = await MockContract.new() let methodId = await crvRenWSBTCContract.methods.balanceOf(sender).encodeABI();
const crvRenWSBTCContract = new web3.eth.Contract(erc20ABI, mock.address); await mock.givenMethodReturnUint(methodId, 10000000);
let methodId = await crvRenWSBTCContract.methods.banlanceOf.getData(0,0);
console.log("methodId: ", methodId);
await mock.givenMethodReturn(methodId, abi.rawEncode(['uint'], [10000000]).toString());
let crvRenWSBTC = await crvRenWSBTCContract.methods.balanceOf(sender).call(); let crvRenWSBTC = await crvRenWSBTCContract.methods.balanceOf(sender).call();
console.log("Sender crvRenWSBTC Before: ", crvRenWSBTC.toString());
expect(crvRenWSBTC).to.be(10000000); expect(crvRenWSBTC).to.equal("10000000");
// expect(wbtcAfter - wbtcBefore).to.be.at.least(10000000);
}) })
it('can mock token', async function() {
// expect(wbtcAfter - wbtcBefore).to.be.at.least(10000000);
});
}) })

View File

@ -0,0 +1 @@
[{"name":"Transfer","inputs":[{"type":"address","name":"_from","indexed":true},{"type":"address","name":"_to","indexed":true},{"type":"uint256","name":"_value","indexed":false}],"anonymous":false,"type":"event"},{"name":"Approval","inputs":[{"type":"address","name":"_owner","indexed":true},{"type":"address","name":"_spender","indexed":true},{"type":"uint256","name":"_value","indexed":false}],"anonymous":false,"type":"event"},{"outputs":[],"inputs":[{"type":"string","name":"_name"},{"type":"string","name":"_symbol"},{"type":"uint256","name":"_decimals"},{"type":"uint256","name":"_supply"}],"constant":false,"payable":false,"type":"constructor"},{"name":"set_minter","outputs":[],"inputs":[{"type":"address","name":"_minter"}],"constant":false,"payable":false,"type":"function","gas":36247},{"name":"totalSupply","outputs":[{"type":"uint256","name":"out"}],"inputs":[],"constant":true,"payable":false,"type":"function","gas":1181},{"name":"allowance","outputs":[{"type":"uint256","name":"out"}],"inputs":[{"type":"address","name":"_owner"},{"type":"address","name":"_spender"}],"constant":true,"payable":false,"type":"function","gas":1519},{"name":"transfer","outputs":[{"type":"bool","name":"out"}],"inputs":[{"type":"address","name":"_to"},{"type":"uint256","name":"_value"}],"constant":false,"payable":false,"type":"function","gas":74802},{"name":"transferFrom","outputs":[{"type":"bool","name":"out"}],"inputs":[{"type":"address","name":"_from"},{"type":"address","name":"_to"},{"type":"uint256","name":"_value"}],"constant":false,"payable":false,"type":"function","gas":111953},{"name":"approve","outputs":[{"type":"bool","name":"out"}],"inputs":[{"type":"address","name":"_spender"},{"type":"uint256","name":"_value"}],"constant":false,"payable":false,"type":"function","gas":39012},{"name":"mint","outputs":[],"inputs":[{"type":"address","name":"_to"},{"type":"uint256","name":"_value"}],"constant":false,"payable":false,"type":"function","gas":75733},{"name":"burn","outputs":[],"inputs":[{"type":"uint256","name":"_value"}],"constant":false,"payable":false,"type":"function","gas":76623},{"name":"burnFrom","outputs":[],"inputs":[{"type":"address","name":"_to"},{"type":"uint256","name":"_value"}],"constant":false,"payable":false,"type":"function","gas":76696},{"name":"name","outputs":[{"type":"string","name":"out"}],"inputs":[],"constant":true,"payable":false,"type":"function","gas":7853},{"name":"symbol","outputs":[{"type":"string","name":"out"}],"inputs":[],"constant":true,"payable":false,"type":"function","gas":6906},{"name":"decimals","outputs":[{"type":"uint256","name":"out"}],"inputs":[],"constant":true,"payable":false,"type":"function","gas":1511},{"name":"balanceOf","outputs":[{"type":"uint256","name":"out"}],"inputs":[{"type":"address","name":"arg0"}],"constant":true,"payable":false,"type":"function","gas":1695}]

View File

@ -1,40 +1,10 @@
/**
* Use this file to configure your truffle project. It's seeded with some
* common settings for different networks and features like migrations,
* compilation and testing. Uncomment the ones you need or modify
* them to suit your project as necessary.
*
* More information about configuration can be found at:
*
* truffleframework.com/docs/advanced/configuration
*
* To deploy via Infura you'll need a wallet provider (like truffle-hdwallet-provider)
* to sign your transactions before they're sent to a remote public node. Infura accounts
* are available for free at: infura.io/register.
*
* You'll also need a mnemonic - the twelve word phrase the wallet uses to generate
* public/private key pairs. If you're publishing your code to GitHub make sure you load this
* phrase from a file you've .gitignored so it doesn't accidentally become public.
*
*/
const HDWalletProvider = require('truffle-hdwallet-provider'); const HDWalletProvider = require('truffle-hdwallet-provider');
const dotenv = require('dotenv'); const dotenv = require('dotenv');
dotenv.config(); dotenv.config();
const infuraKey = process.env.infura_key; const infuraKey = process.env.infura_key;
//
const mnemonic = process.env.mnemonic_key; const mnemonic = process.env.mnemonic_key;
module.exports = { module.exports = {
/**
* Networks define how you connect to your ethereum client and let you set the
* defaults web3 uses to send transactions. If you don't specify one truffle
* will spin up a development blockchain for you on port 9545 when you
* run `develop` or `test`. You can ask a truffle command to use a specific
* network from the command line, e.g
*
* $ truffle test --network <network-name>
*/
plugins: [ plugins: [
'truffle-plugin-verify', 'truffle-plugin-verify',
], ],
@ -43,36 +13,18 @@ module.exports = {
}, },
networks: { networks: {
// Useful for testing. The `development` name is special - truffle uses it by default
// if it's defined here and no other network is specified at the command line.
// You should run a client (like ganache-cli, geth or parity) in a separate terminal
// tab if you use this network and you must also set the `host`, `port` and `network_id`
// options below to some value.
//
development: { development: {
host: "127.0.0.1", // Localhost (default: none) host: "127.0.0.1",
port: 8545, // Standard Ethereum port (default: none) port: 8545,
network_id: "*", // Any network (default: none) network_id: "*",
}, },
// Tenderly Proxy
proxy: { proxy: {
host: "127.0.0.1", // Localhost (default: none) host: "127.0.0.1",
port: 9545, // Standard Ethereum port (default: none) port: 9545,
network_id: "*", // Any network (default: none) network_id: "*",
}, },
// Another network with more advanced options...
// advanced: {
// port: 8777, // Custom port
// network_id: 1342, // Custom network
// gas: 8500000, // Gas sent with each transaction (default: ~6700000)
// gasPrice: 20000000000, // 20 gwei (in wei) (default: 100 gwei)
// from: <address>, // Account to send txs from (default: accounts[0])
// websockets: true // Enable EventEmitter interface for web3 (default: false)
// },
// Useful for deploying to a public network.
// NB: It's important to wrap the provider as a function.
live: { live: {
provider: () => new HDWalletProvider(mnemonic, `https://mainnet.infura.io/v3/${infuraKey}`), provider: () => new HDWalletProvider(mnemonic, `https://mainnet.infura.io/v3/${infuraKey}`),
network_id: 1, network_id: 1,
@ -97,13 +49,6 @@ module.exports = {
timeoutBlocks: 200, // # of blocks before a deployment times out (minimum/default: 50) timeoutBlocks: 200, // # of blocks before a deployment times out (minimum/default: 50)
skipDryRun: true // Skip dry run before migrations? (default: false for public nets ) skipDryRun: true // Skip dry run before migrations? (default: false for public nets )
}, },
// Useful for private networks
// private: {
// provider: () => new HDWalletProvider(mnemonic, `https://network.io`),
// network_id: 2111, // This network is yours, in the cloud.
// production: true // Treats this network as if it was a public net. (default: false)
// }
}, },
// Set default mocha options here, use special reporters etc. // Set default mocha options here, use special reporters etc.
@ -114,15 +59,13 @@ module.exports = {
// Configure your compilers // Configure your compilers
compilers: { compilers: {
solc: { solc: {
version: "v0.6.2", // Fetch exact version from solc-bin (default: truffle's version) version: "v0.6.2",
// docker: true, // Use "0.5.1" you've installed locally with docker (default: false) settings: {
// settings: { // See the solidity docs for advice about optimization and evmVersion optimizer: {
// optimizer: { enabled: true,
enabled: false, },
// runs: 200 // evmVersion: "istanbul"
// }, }
// evmVersion: "istanbul"
// }
} }
} }
} }