2019-04-08 17:28:36 +00:00
|
|
|
/*global contract, config, it, embark, web3, before, describe, beforeEach*/
|
|
|
|
const TestUtils = require("../utils/testUtils");
|
|
|
|
|
|
|
|
const DAppStore = require('Embark/contracts/DAppStore');
|
|
|
|
const SNT = embark.require('Embark/contracts/SNT');
|
|
|
|
|
|
|
|
|
|
|
|
config({
|
|
|
|
deployment: {
|
|
|
|
accounts: [
|
|
|
|
{
|
|
|
|
mnemonic: "foster gesture flock merge beach plate dish view friend leave drink valley shield list enemy",
|
|
|
|
balance: "5 ether",
|
|
|
|
numAddresses: "10"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
},
|
|
|
|
contracts: {
|
|
|
|
"MiniMeToken": { "deploy": false },
|
|
|
|
"MiniMeTokenFactory": { },
|
|
|
|
"SNT": {
|
|
|
|
"instanceOf": "MiniMeToken",
|
|
|
|
"args": [
|
|
|
|
"$MiniMeTokenFactory",
|
|
|
|
"0x0000000000000000000000000000000000000000",
|
|
|
|
0,
|
|
|
|
"TestMiniMeToken",
|
|
|
|
18,
|
|
|
|
"SNT",
|
|
|
|
true
|
|
|
|
]
|
|
|
|
},
|
|
|
|
"DAppStore": {
|
|
|
|
args: [ "$SNT" ]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}, (_err, web3_accounts) => {
|
|
|
|
accounts = web3_accounts
|
|
|
|
});
|
|
|
|
|
|
|
|
contract("DAppStore", function () {
|
|
|
|
|
|
|
|
this.timeout(0);
|
|
|
|
|
|
|
|
it("should set max and safeMax values correctly", async function () {
|
|
|
|
let resultMax = await DAppStore.methods.max().call();
|
|
|
|
let resultSafeMax = await DAppStore.methods.safeMax().call();
|
|
|
|
let expectedMax = Math.round(3470483788 * 588 / 1000000);
|
|
|
|
let expectedSafeMax = Math.round(expectedMax * 0.98);
|
|
|
|
assert.strictEqual(parseInt(resultMax, 10), expectedMax);
|
|
|
|
assert.strictEqual(parseInt(resultSafeMax, 10), expectedSafeMax);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should create a new DApp and initialise it correctly", async function () {
|
|
|
|
let id = "0x7465737400000000000000000000000000000000000000000000000000000000";
|
2019-04-08 20:11:06 +00:00
|
|
|
let amount = 100000;
|
2019-04-08 17:28:36 +00:00
|
|
|
|
|
|
|
await SNT.methods.generateTokens(accounts[0], amount).send();
|
|
|
|
const encodedCall = DAppStore.methods.createDApp(id,amount).encodeABI();
|
|
|
|
await SNT.methods.approveAndCall(DAppStore.options.address, amount, encodedCall).send({from: accounts[0]});
|
|
|
|
|
|
|
|
let receipt = await DAppStore.methods.dapps(0).call();
|
|
|
|
|
|
|
|
let developer = accounts[0];
|
|
|
|
assert.strictEqual(receipt.developer, developer);
|
|
|
|
|
|
|
|
assert.strictEqual(receipt.id, id);
|
|
|
|
assert.strictEqual(parseInt(receipt.balance, 10), amount);
|
|
|
|
|
|
|
|
let max = await DAppStore.methods.max().call();
|
|
|
|
let decimals = await DAppStore.methods.decimals().call();
|
|
|
|
let rate = Math.round(decimals - (amount * decimals/max));
|
|
|
|
assert.strictEqual(parseInt(receipt.rate, 10), rate);
|
|
|
|
|
|
|
|
let available = amount * rate;
|
|
|
|
assert.strictEqual(parseInt(receipt.available, 10), available);
|
|
|
|
|
|
|
|
let votes_minted = Math.round((available/decimals) ** (decimals/rate));
|
|
|
|
assert.strictEqual(parseInt(receipt.votes_minted, 10), votes_minted);
|
|
|
|
|
|
|
|
assert.strictEqual(parseInt(receipt.votes_cast, 10), 0);
|
|
|
|
assert.strictEqual(parseInt(receipt.effective_balance, 10), amount);
|
|
|
|
})
|
2019-04-08 19:22:45 +00:00
|
|
|
|
|
|
|
it("should handle first upvote correctly", async function () {
|
|
|
|
let id = "0x7465737400000000000000000000000000000000000000000000000000000000";
|
|
|
|
let amount = 100;
|
|
|
|
|
|
|
|
let initial = await DAppStore.methods.dapps(0).call();
|
|
|
|
|
|
|
|
await SNT.methods.generateTokens(accounts[0], amount).send();
|
|
|
|
const encodedCall = DAppStore.methods.upvote(id,amount).encodeABI();
|
|
|
|
await SNT.methods.approveAndCall(DAppStore.options.address, amount, encodedCall).send({from: accounts[0]});
|
|
|
|
|
|
|
|
let receipt = await DAppStore.methods.dapps(0).call();
|
|
|
|
|
|
|
|
let developer = accounts[0];
|
|
|
|
assert.strictEqual(receipt.developer, developer);
|
|
|
|
|
|
|
|
assert.strictEqual(receipt.id, id);
|
|
|
|
|
|
|
|
let upvotedBalance = parseInt(initial.balance, 10) + amount
|
|
|
|
assert.strictEqual(parseInt(receipt.balance, 10), upvotedBalance);
|
|
|
|
|
|
|
|
let max = await DAppStore.methods.max().call();
|
|
|
|
let decimals = await DAppStore.methods.decimals().call();
|
|
|
|
let rate = Math.round(decimals - (upvotedBalance * decimals/max));
|
|
|
|
assert.strictEqual(parseInt(receipt.rate, 10), rate);
|
|
|
|
|
|
|
|
let available = upvotedBalance * rate;
|
|
|
|
assert.strictEqual(parseInt(receipt.available, 10), available);
|
|
|
|
|
|
|
|
let votes_minted = Math.round((available/decimals) ** (decimals/rate));
|
|
|
|
assert.strictEqual(parseInt(receipt.votes_minted, 10), votes_minted);
|
|
|
|
|
|
|
|
assert.strictEqual(parseInt(receipt.votes_cast, 10), 0);
|
|
|
|
|
|
|
|
assert.strictEqual(parseInt(receipt.effective_balance, 10), upvotedBalance);
|
|
|
|
})
|
|
|
|
|
|
|
|
it("should handle first downvote correctly", async function () {
|
|
|
|
let id = "0x7465737400000000000000000000000000000000000000000000000000000000";
|
|
|
|
let cost = await DAppStore.methods.downvoteCost(id).call()
|
|
|
|
let amount = parseInt(cost.c, 10);
|
|
|
|
|
|
|
|
let initial = await DAppStore.methods.dapps(0).call();
|
|
|
|
|
2019-04-08 20:11:06 +00:00
|
|
|
await SNT.methods.generateTokens(accounts[1], amount).send();
|
2019-04-08 19:22:45 +00:00
|
|
|
const encodedCall = DAppStore.methods.downvote(id,amount).encodeABI();
|
2019-04-09 07:16:48 +00:00
|
|
|
await SNT.methods.approveAndCall(DAppStore.options.address, amount, encodedCall).send({from: accounts[1]});
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
let receipt = await DAppStore.methods.dapps(0).call();
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
let developer = accounts[0];
|
|
|
|
assert.strictEqual(receipt.developer, developer);
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
assert.strictEqual(receipt.id, id);
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
// Balance, rate, and votes_minted remain unchanged for downvotes
|
|
|
|
assert.strictEqual(receipt.balance, initial.balance);
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
assert.strictEqual(receipt.rate, initial.rate);
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
assert.strictEqual(receipt.votes_minted, initial.votes_minted);
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
let available = parseInt(initial.available, 10) - parseInt(cost.c, 10);
|
|
|
|
assert.strictEqual(parseInt(receipt.available, 10), available);
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
assert.strictEqual(parseInt(receipt.votes_cast, 10), parseInt(cost.v_r, 10));
|
2019-04-08 19:22:45 +00:00
|
|
|
|
2019-04-09 07:16:48 +00:00
|
|
|
let e_balance = parseInt(initial.effective_balance, 10) - parseInt(cost.b, 10);
|
|
|
|
assert.strictEqual(parseInt(receipt.effective_balance, 10), e_balance);
|
2019-04-08 19:22:45 +00:00
|
|
|
})
|
2019-04-08 17:28:36 +00:00
|
|
|
});
|