Skip to content

Commit

Permalink
Make test work
Browse files Browse the repository at this point in the history
  • Loading branch information
brizental committed Feb 8, 2023
1 parent f7142d7 commit 8e6a5d6
Showing 1 changed file with 165 additions and 153 deletions.
318 changes: 165 additions & 153 deletions tests/functional/testAddons.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,176 +11,188 @@ const { startAndConnect } = require('./setupVpn.js')
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;
// });
// });

// it('Broken addon index', async () => {
// await vpn.resetAddons('03_single_addon');
// await vpn.waitForCondition(async () => {
// return parseInt(
// 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;
// });
// });

// it('Addons are loaded', async () => {
// await vpn.resetAddons('03_single_addon');
// await vpn.waitForCondition(async () => {
// return parseInt(
// 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.fetchAddons('03_single_addon');
// await vpn.waitForCondition(async () => {
// return parseInt(
// await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) ===
// 1;
// });
// });

// it('Settings rollback - location', async () => {
// // Loading the custom tutorial
// await vpn.resetAddons('05_settings_rollback');

// await vpn.waitForCondition(async () => {
// return parseInt(
// await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) ===
// 1;
// });

// const exitCityName =
// await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName');
// const 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());
// await vpn.waitForQueryAndClick(
// queries.screenSettings.TUTORIAL_LIST_HIGHLIGHT.visible());

// // Confirmation dialog for settings-rollback
// await vpn.waitForQuery(
// queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible());
// assert(
// (await vpn.getQueryProperty(
// queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible(),
// 'text')) === 'Continue');
// await vpn.clickOnQuery(
// queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible());

// await vpn.waitForCondition(async () => {
// return await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') ===
// 'Vienna';
// });

// assert(
// await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') ===
// 'Vienna');
// assert(
// await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode') ===
// 'at');

// await vpn.waitForQuery(queries.screenHome.TUTORIAL_LEAVE.visible());
// await vpn.waitForQueryAndClick(
// queries.screenHome.SERVER_LIST_BUTTON.visible());

// // Final dialog
// await vpn.waitForQuery(
// queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible());
// assert(
// (await vpn.getQueryProperty(
// queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible(),
// 'text')) === 'Let’s go!');
// await vpn.clickOnQuery(
// queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible());

// await vpn.waitForCondition(async () => {
// return await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') ===
// exitCityName;
// });

// assert(
// await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') ===
// exitCityName);
// assert(
// await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode') ===
// exitCountryCode);
// });
it('Empty addon index', async () => {
await vpn.resetAddons('01_empty_manifest');
await vpn.waitForCondition(async () => {
return parseInt(
await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) ===
0;
});
});

it('Broken addon index', async () => {
await vpn.resetAddons('03_single_addon');
await vpn.waitForCondition(async () => {
return parseInt(
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;
});
});

it('Addons are loaded', async () => {
await vpn.resetAddons('03_single_addon');
await vpn.waitForCondition(async () => {
return parseInt(
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.fetchAddons('03_single_addon');
await vpn.waitForCondition(async () => {
return parseInt(
await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) ===
1;
});
});

it('Settings rollback - location', async () => {
// Loading the custom tutorial
await vpn.resetAddons('05_settings_rollback');

await vpn.waitForCondition(async () => {
return parseInt(
await vpn.getVPNProperty('VPNAddonManager', 'count'), 10) ===
1;
});

const exitCityName =
await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName');
const 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());
await vpn.waitForQueryAndClick(
queries.screenSettings.TUTORIAL_LIST_HIGHLIGHT.visible());

// Confirmation dialog for settings-rollback
await vpn.waitForQuery(
queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible());
assert(
(await vpn.getQueryProperty(
queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible(),
'text')) === 'Continue');
await vpn.clickOnQuery(
queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible());

await vpn.waitForCondition(async () => {
return await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') ===
'Vienna';
});

assert(
await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') ===
'Vienna');
assert(
await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode') ===
'at');

await vpn.waitForQuery(queries.screenHome.TUTORIAL_LEAVE.visible());
await vpn.waitForQueryAndClick(
queries.screenHome.SERVER_LIST_BUTTON.visible());

// Final dialog
await vpn.waitForQuery(
queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible());
assert(
(await vpn.getQueryProperty(
queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible(),
'text')) === 'Let’s go!');
await vpn.clickOnQuery(
queries.screenHome.TUTORIAL_POPUP_PRIMARY_BUTTON.visible());

await vpn.waitForCondition(async () => {
return await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') ===
exitCityName;
});

assert(
await vpn.getVPNProperty('VPNCurrentServer', 'exitCityName') ===
exitCityName);
assert(
await vpn.getVPNProperty('VPNCurrentServer', 'exitCountryCode') ===
exitCountryCode);
});

describe('test message_subscription_expiring addon condition', async () => {
const subscriptionAboutToExpire = Array.from(
{ length: 7 },
// 1 to 7 days out from expiring.
(_, i) => [Date.now() + 1000 * 60 * 60 * 24 * (i + 1), true]
);

const subscriptionIsFarFromExpiring = [
// Seven days out + a minute from expiring.
[Date.now() + 1000 * 60 * 60 * 24 * 7 + 1000 * 60, false],
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],
[Date.now() + 1000 * 60 * 60 * 24 * 8, false, "is 8 days away"],
// One month from expiring.
[Date.now() + 1000 * 60 * 60 * 24 * 30, false],
];

const subscriptionHasExpired = [
[Date.now() + 1000 * 60 * 60 * 24 * 30, false, "is one month away"],
// Literally, has just expired.
[Date.now(), false],
[Date.now(), false, "just happened"],
// Has been expired for a day.
[Date.now() - 1000 * 60 * 60 * 24, false],
[Date.now() - 1000 * 60 * 60 * 24, false, "was yesterday"],
// Has been expired for 30 days.
[Date.now() - 1000 * 60 * 60 * 24 * 30, false],
[Date.now() - 1000 * 60 * 60 * 24 * 30, false, "was last month"],
];

[
...subscriptionAboutToExpire,
...subscriptionIsFarFromExpiring,
...subscriptionHasExpired,
].forEach(([expiresOn, shouldBeAvailable]) => {
const getNextTestCase = testCases[Symbol.iterator]();
function setNextSubscriptionExpiry(ctx) {
const mockDetails = { ...SubscriptionDetails };
// We are faking a Stripe subscription, so this value is expected to be in seconds.
mockDetails.subscription.current_period_end = expiresOn / 1000;
this.ctx.guardianSubscriptionDetailsCallback = () => {
this.ctx.guardianOverrideEndpoints.GETs['/api/v1/vpn/subscriptionDetails'].status = 200;
this.ctx.guardianOverrideEndpoints
.GETs['/api/v1/vpn/subscriptionDetails']
.body = mockDetails;
};

it(`message display is correct for subscription expiration on ${expiresOn}`, async () => {
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
));

const loadedMessages = await vpn.messages();
const isSubscriptionExpiringMessageAvailable = loadedMessages.includes("message_subscription_expiring");
assert(shouldBeAvailable ? isSubscriptionExpiringMessageAvailable : !isSubscriptionExpiringMessageAvailable);

// 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;
});
});
});
});
Expand Down

0 comments on commit 8e6a5d6

Please sign in to comment.