diff --git a/tests/functional/testAddons.js b/tests/functional/testAddons.js index 0bac2cf4494..60a27b68190 100644 --- a/tests/functional/testAddons.js +++ b/tests/functional/testAddons.js @@ -5,18 +5,18 @@ const assert = require('assert'); const queries = require('./queries.js'); const vpn = require('./helper.js'); -const { SubscriptionDetails } = require('./servers/guardian_endpoints.js') -const { startAndConnect } = require('./setupVpn.js') +const { SubscriptionDetails } = require('./servers/guardian_endpoints.js'); +const { env, TestingEnvironments } = require('./helper.js'); -describe('Addons', function() { +describe('Addons', function () { this.ctx.authenticationNeeded = true; it('Empty addon index', async () => { await vpn.resetAddons('01_empty_manifest'); await vpn.waitForCondition(async () => { return parseInt( - await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === - 0; + await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === + 0; }); }); @@ -24,15 +24,15 @@ describe('Addons', function() { await vpn.resetAddons('03_single_addon'); await vpn.waitForCondition(async () => { return parseInt( - await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === - 1; + await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === + 1; }); await vpn.fetchAddons('02_broken_manifest'); await vpn.waitForCondition(async () => { return parseInt( - await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === - 1; + await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === + 1; }); }); @@ -40,22 +40,22 @@ describe('Addons', function() { await vpn.resetAddons('03_single_addon'); await vpn.waitForCondition(async () => { return parseInt( - await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === - 1; + await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === + 1; }); await vpn.fetchAddons('01_empty_manifest'); await vpn.waitForCondition(async () => { return parseInt( - await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === - 0; + await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === + 0; }); await vpn.fetchAddons('03_single_addon'); await vpn.waitForCondition(async () => { return parseInt( - await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === - 1; + await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === + 1; }); }); @@ -65,135 +65,139 @@ describe('Addons', function() { await vpn.waitForCondition(async () => { return parseInt( - await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === - 1; + await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) === + 1; }); const exitCityName = - await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName'); + await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName'); const exitCountryCode = - await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode'); + await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode'); // Let's start the tutorial await vpn.waitForQueryAndClick(queries.navBar.SETTINGS.visible()); await vpn.waitForQueryAndClick( - queries.screenSettings.TIPS_AND_TRICKS.visible()); + queries.screenSettings.TIPS_AND_TRICKS.visible()); await vpn.waitForQueryAndClick( - queries.screenSettings.TUTORIAL_LIST_HIGHLIGHT.visible()); + queries.screenSettings.TUTORIAL_LIST_HIGHLIGHT.visible()); // Confirmation dialog for settings-rollback await vpn.waitForQuery( - queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible()); + queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible()); assert( - (await vpn.getQueryProperty( - queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible(), - 'text')) === 'Continue'); + (await vpn.getQueryProperty( + queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible(), + 'text')) === 'Continue'); await vpn.clickOnQuery( - queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible()); + queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible()); await vpn.waitForCondition(async () => { return await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') === - 'Vienna'; + 'Vienna'; }); assert( - await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') === - 'Vienna'); + await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') === + 'Vienna'); assert( - await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode') === - 'at'); + await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode') === + 'at'); await vpn.waitForQuery(queries.screenHome.TUTORIAL_LEAVE.visible()); await vpn.waitForQueryAndClick( - queries.screenHome.SERVER_LIST_BUTTON.visible()); + queries.screenHome.SERVER_LIST_BUTTON.visible()); // Final dialog await vpn.waitForQuery( - queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible()); + queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible()); assert( - (await vpn.getQueryProperty( - queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible(), - 'text')) === 'Let’s go!'); + (await vpn.getQueryProperty( + queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible(), + 'text')) === 'Let’s go!'); await vpn.clickOnQuery( - queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible()); + queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible()); await vpn.waitForCondition(async () => { return await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') === - exitCityName; + exitCityName; }); assert( - await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') === - exitCityName); + await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') === + exitCityName); assert( - await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode') === - exitCountryCode); + await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode') === + exitCountryCode); }); - describe('test message_subscription_expiring addon condition', async () => { - const testCases = [ - ...Array.from( - { length: 7 }, - // 1 to 7 days out from expiring. - (_, i) => [Date.now() + 1000 * 60 * 60 * 24 * (i + 1), true, `is ${i + 1} day(s) away`] - ), - // Seven days out + five minutes from expiring. - [Date.now() + 1000 * 60 * 60 * 24 * 7 + 1000 * 60 * 5, false, "is 7 days and five minutes away"], - // Eight days from expiring. - [Date.now() + 1000 * 60 * 60 * 24 * 8, false, "is 8 days away"], - // One month from expiring. - [Date.now() + 1000 * 60 * 60 * 24 * 30, false, "is one month away"], - // Literally, has just expired. - [Date.now(), false, "just happened"], - // Has been expired for a day. - [Date.now() - 1000 * 60 * 60 * 24, false, "was yesterday"], - // Has been expired for 30 days. - [Date.now() - 1000 * 60 * 60 * 24 * 30, false, "was last month"], - ]; - - const getNextTestCase = testCases[Symbol.iterator](); - function setNextSubscriptionExpiry(ctx) { - const mockDetails = { ...SubscriptionDetails }; - const nextTestCase = getNextTestCase.next().value; - - if (nextTestCase) { - const [ expiresOn ] = nextTestCase; - // We are faking a Stripe subscription, so this value is expected to be in seconds. - mockDetails.subscription.current_period_end = expiresOn / 1000; - - ctx.guardianSubscriptionDetailsCallback = () => { - ctx.guardianOverrideEndpoints.GETs['/api/v1/vpn/subscriptionDetails'].status = 200; - ctx.guardianOverrideEndpoints - .GETs['/api/v1/vpn/subscriptionDetails'] - .body = mockDetails; - }; + // This tests cannot be run in WASM due to Qt limitations. + // See: https://mozilla-hub.atlassian.net/browse/VPN-4127 + if (typeof process === "object") { + describe('test message_subscription_expiring addon condition', async () => { + const testCases = [ + ...Array.from( + { length: 7 }, + // 1 to 7 days out from expiring. + (_, i) => [Date.now() + 1000 * 60 * 60 * 24 * (i + 1), true, `is ${i + 1} day(s) away`] + ), + // Seven days out + five minutes from expiring. + [Date.now() + 1000 * 60 * 60 * 24 * 7 + 1000 * 60 * 5, false, "is 7 days and five minutes away"], + // Eight days from expiring. + [Date.now() + 1000 * 60 * 60 * 24 * 8, false, "is 8 days away"], + // One month from expiring. + [Date.now() + 1000 * 60 * 60 * 24 * 30, false, "is one month away"], + // Literally, has just expired. + [Date.now(), false, "just happened"], + // Has been expired for a day. + [Date.now() - 1000 * 60 * 60 * 24, false, "was yesterday"], + // Has been expired for 30 days. + [Date.now() - 1000 * 60 * 60 * 24 * 30, false, "was last month"], + ]; + + const getNextTestCase = testCases[Symbol.iterator](); + function setNextSubscriptionExpiry(ctx) { + const mockDetails = { ...SubscriptionDetails }; + const nextTestCase = getNextTestCase.next().value; + + if (nextTestCase) { + const [expiresOn] = nextTestCase; + // We are faking a Stripe subscription, so this value is expected to be in seconds. + mockDetails.subscription.current_period_end = expiresOn / 1000; + + ctx.guardianSubscriptionDetailsCallback = () => { + ctx.guardianOverrideEndpoints.GETs['/api/v1/vpn/subscriptionDetails'].status = 200; + ctx.guardianOverrideEndpoints + .GETs['/api/v1/vpn/subscriptionDetails'] + .body = mockDetails; + }; + } } - } - - // We call this once before all tests to set up the first test, - // we can't use beforeEach because that is executed after the guardian endpoints are overriden. - // - // We need to setup for the next test before it even starts for the overrides to apply. - setNextSubscriptionExpiry(this.ctx); - afterEach(() => setNextSubscriptionExpiry(this.ctx)); - - testCases.forEach(([_, shouldBeAvailable, testCase]) => { - it(`message display is correct when subscription expiration ${testCase}`, async () => { - // Load all production addons. - // These are loaded all together, so we don't know the exact number of addons. - await vpn.resetAddons('prod'); - await vpn.waitForCondition(async () => ( - parseInt(await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) > 0 - )); - - - // Check if the message is there or not. - await vpn.waitForCondition(async () => { - const loadedMessages = await vpn.messages(); - const isSubscriptionExpiringMessageAvailable = loadedMessages.includes("message_subscription_expiring"); - return shouldBeAvailable ? isSubscriptionExpiringMessageAvailable : !isSubscriptionExpiringMessageAvailable; + + // We call this once before all tests to set up the first test, + // we can't use beforeEach because that is executed after the guardian endpoints are overriden. + // + // We need to setup for the next test before it even starts for the overrides to apply. + setNextSubscriptionExpiry(this.ctx); + afterEach(() => setNextSubscriptionExpiry(this.ctx)); + + testCases.forEach(([_, shouldBeAvailable, testCase]) => { + it(`message display is correct when subscription expiration ${testCase}`, async () => { + // Load all production addons. + // These are loaded all together, so we don't know the exact number of addons. + await vpn.resetAddons('prod'); + await vpn.waitForCondition(async () => ( + parseInt(await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) > 0 + )); + + + // Check if the message is there or not. + await vpn.waitForCondition(async () => { + const loadedMessages = await vpn.messages(); + const isSubscriptionExpiringMessageAvailable = loadedMessages.includes("message_subscription_expiring"); + return shouldBeAvailable ? isSubscriptionExpiringMessageAvailable : !isSubscriptionExpiringMessageAvailable; + }); }); }); }); - }); + } });