let test = require('selenium-webdriver/testing'); let assert = require('assert'); const fs = require('fs-extra'); /////////////////////////////////////////////////////// const WizardWelcome = require('../pages/WizardWelcome.js').WizardWelcome; const WizardStep1 = require('../pages/WizardStep1.js').WizardStep1; const WizardStep2 = require('../pages/WizardStep2.js').WizardStep2; const WizardStep3 = require('../pages/WizardStep3.js').WizardStep3; const WizardStep4 = require('../pages/WizardStep4.js').WizardStep4; const TierPage = require('../pages/TierPage.js').TierPage; const ReservedTokensPage = require('../pages/ReservedTokensPage.js').ReservedTokensPage; const CrowdsalePage = require('../pages/CrowdsalePage.js').CrowdsalePage; const InvestPage = require('../pages/ContributionPage.js').InvestPage; const ManagePage = require('../pages/ManagePage.js').ManagePage; const logger = require('../entity/Logger.js').logger; const tempOutputPath = require('../entity/Logger.js').tempOutputPath; const Utils = require('../utils/Utils.js').Utils; const MetaMask = require('../pages/MetaMask.js').MetaMask; const User = require("../entity/User.js").User; const Crowdsale = require('../entity/Crowdsale.js').Crowdsale; const smallAmount = 0.1; const endTimeForTestEarlier = "01:23"; const endDateForTestEarlier = "01/07/2049"; const endTimeForTestLater = "420000"; const endDateForTestLater = "420000"; test.describe('POA token-wizard. Test DutchAuction Ropsten', async function () { this.timeout(2400000);//40 min this.slow(1800000); const user3_56B2File = './users/user3_56B2.json'; const user3_0e03File = './users/user3_0e03.json'; const user8545_56B2File = './users/user8545_56B2.json';//Owner const user8545_F16AFile = './users/user8545_F16A.json';//Investor1 - whitelisted for Tier#1 before deployment const user8545_f5aAFile = './users/user8545_f5aA.json';//Investor2 - added from manage page before start const user8545_ecDFFile = './users/user8545_ecDF.json';//Reserved address, also wh investor that added after start time const user8545_dDdCFile = './users/user8545_dDdC.json';//Investor3 - whitelisted for Tier#2 before deployment let driver; let Owner; let Investor1; let Investor2; let Investor3; let ReservedAddress; let metaMask; let welcomePage; let wizardStep1; let wizardStep2; let wizardStep3; let wizardStep4; let tierPage; let reservedTokensPage; let investPage; let startURL; let crowdsaleForUItests; let e2eMinCap; let e2eWhitelist; let e2eMultitier; let mngPage; let balance; let endTime; let endDate; let e2eRopsten; ///////////////////////////////////////////////////////////////////////// test.before(async function () { logger.info("Take function rate-time for dutch, Ropsten "); const scenarioDutchFuncRateTime = './scenarios/scenarioDutchFuncRateTime.json'; e2eRopsten = await Utils.getDutchCrowdsaleInstance(scenarioDutchFuncRateTime); startURL = await Utils.getStartURL(); driver = await Utils.startBrowserWithWallet(); Owner = new User(driver, user3_0e03File); metaMask = new MetaMask(driver); await metaMask.activate();//return activated Metamask and empty page await Owner.setWalletAccount(); welcomePage = new WizardWelcome(driver, startURL); wizardStep1 = new WizardStep1(driver); wizardStep2 = new WizardStep2(driver); wizardStep3 = new WizardStep3(driver); wizardStep4 = new WizardStep4(driver); investPage = new InvestPage(driver); reservedTokensPage = new ReservedTokensPage(driver); mngPage = new ManagePage(driver); }); test.after(async function () { // Utils.killProcess(ganache); //await Utils.sendEmail(tempOutputFile); let outputPath = Utils.getOutputPath(); outputPath = outputPath + "/result" + Utils.getDate(); await fs.ensureDirSync(outputPath); await fs.copySync(tempOutputPath, outputPath); //await fs.remove(tempOutputPath); //await driver.quit(); }); //////////////////////// Test SUITE #1 ///////////////////////////// test.it('ceate crowdsale, duration 5 min', async function () { let owner = Owner; assert.equal(await owner.setWalletAccount(), true, "Can not set Metamask account"); let result = await owner.createDutchAuctionCrowdsale(e2eRopsten); return await assert.equal(result, true, 'Test FAILED. Crowdsale has not created '); }); test.it('Tier starts as scheduled', async function () { let investor = Owner; assert.equal(await investor.openInvestPage(e2eRopsten), true, 'Investor can not open Invest page'); assert.equal(await investPage.waitUntilLoaderGone(), true, 'Loader displayed too long time'); let counter = 1080; do { logger.info("wait " + Date.now()); await driver.sleep(1000); } while (counter-- > 0 && !await investPage.isCrowdsaleStarted()); return await assert.equal(counter > 0, true, 'Test FAILED. Tier has not start in time '); }); test.it('take function rate-time ', async function () { let file = await Utils.takeFunctionRateTime(e2eRopsten); let result = (file !== null); return await assert.equal(result, true, 'Test FAILED. '); }); });