Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Nadia dec3 wv 787 wv 894 #4190

Merged
merged 6 commits into from
Dec 3, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion src/js/components/CandidateListRoot/CandidateListRoot.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -404,7 +404,7 @@ class CandidateListRoot extends Component {
titleTextForList.length &&
candidateList) &&
(
<WhatIsHappeningTitle>
<WhatIsHappeningTitle id="whatIsHappeningTitle">
{titleTextForList}
</WhatIsHappeningTitle>
)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -403,7 +403,7 @@ class RepresentativeListRoot extends Component {
titleTextForList.length &&
representativeList) &&
(
<WhatIsHappeningTitle>
<WhatIsHappeningTitle id="whatIsHappeningTitle">
{titleTextForList}
</WhatIsHappeningTitle>
)}
Expand Down
56 changes: 56 additions & 0 deletions tests/browserstack_automation/page_objects/candidates.page.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
import { $, $$ } from '@wdio/globals';
import Page from './page';
import TopNavigation from './topnavigation';

class CandidatesPage extends Page {
async load () {
await super.open('');
await TopNavigation.toggleCandidatesTab();
}

get stateSelect () {
return $("//select[@id='outlined-age-native-simple']");
}

get stateSelectOptions () {
return $$("//select[@id='outlined-age-native-simple']//option");
}

get pageHeaders () {
return $$('h2#WhatIsHappeningTitle');
}

get CandidateCardList () {
return $$("//div[contains(@id,'cardForListBodyWrapper')]");
}

async getCandidateCardCandidateName(cardId) {
const candidate = await $(`//div[@id='${cardId}']//a[@id='candidateCardDisplayName' or @id='representativeCardDisplayName']`);
const candidateName = await candidate.getText();
return candidateName;
}

async getCandidateCardState(cardId) {
const candidate = await $(`//div[@id='${cardId}']//div[contains(@id,'stateName')]`);
const stateText = await candidate.getText();
return stateText;
}

async getCandidateCardPartyName (cardId) {
const candidateParty = await $(`//div[@id='${cardId}']//div[contains(@class,'PoliticalParty')]`);
const candidatePartyExists = await candidateParty.isExisting();
if (candidatePartyExists) {
const partyText = await candidateParty.getText();
return partyText;
} else {
return null;
}
}

async getCandidateCardOffice (cardId) {
const candidateOffice = await $(`//div[@id='${cardId}']//div[contains(@class,'OfficeNameWrapper')]/div`);
const officeText = candidateOffice.getText();
return officeText;
}
}
export default new CandidatesPage();
155 changes: 155 additions & 0 deletions tests/browserstack_automation/specs/CandidatesPage.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,155 @@
/* eslint-disable no-await-in-loop */
/* eslint-disable no-use-before-define */
import { driver } from '@wdio/globals';
import CandidatesPage from '../page_objects/candidates.page';

const testDataPath = 'tests/browserstack_automation/testDataForScripts/';
const fs = require('fs');
const assert = require('assert');

const waitTime = 8000;

/* eslint-disable no-undef */
// This eslint-disable turns off warnings for describe() and it()

describe('Candidates Page', () => {
// Candidates_001
it('verifyAllStateNamesPresentforChooseState', async () => {
await CandidatesPage.load();
await driver.pause(waitTime);
await CandidatesPage.stateSelect.click();
const options = await CandidatesPage.stateSelectOptions;
const expectedStates = readTestDataStates('all');
const actualStates = [];
await options.forEach(async (option) => {
const stateName = await option.getText();
if (!stateName.includes('Choose state')) {
actualStates.push(stateName);
}
});
await expectedStates.forEach((state) => {
assert(actualStates.includes(state), `State -> '${state}' .. not found on the Choose state Dropdown Options .`);
});
});

// Candidates_002
const stateNamesRandomTC2 = readTestDataStates('random', 3);
stateNamesRandomTC2.forEach((state) => {
it('verifyTitleWhenStateSelected', async () => {
const titleStr = ' Candidates - WeVote';
console.log(`Running verifyTitleWhenStateSelected -> Using sate: ${state}`);
await CandidatesPage.load();
await CandidatesPage.stateSelect.selectByVisibleText(state);
await driver.pause(waitTime);
const expectedTitle = state + titleStr;
const actualTitle = await driver.getTitle();
assert.equal(actualTitle, expectedTitle);
});
});

// Candidates_003
const stateNamesRandomTC3 = readTestDataStates('random', 3);
const possibleHeaders = readTestDataAllPossibleHeaders();
stateNamesRandomTC3.forEach((state) => {
it('verifyHeadersMatchPossibleHeaders', async () => {
console.log(`Running verifyHeadersMatchPossibleHeaders -> Using sate: ${state}`);
CandidatesPage.load();
await driver.pause(waitTime);
await CandidatesPage.stateSelect.selectByVisibleText(state);
await driver.pause(waitTime);
const actualHeaders = await CandidatesPage.pageHeaders;
await actualHeaders.forEach(async (header) => {
const headerText = await header.getText();
console.log(`Checking if Header found on page: '${headerText}' is one of the expected headers.`);
assert(possibleHeaders.includes(headerText), `Header section -> '${headerText}' .. does not match with any of the expected Headers -> [${possibleHeaders}]`);
});
});
});

// Candidates_004
const stateNamesRandomTC4 = readTestDataStates('random', 3);
const MandatoryHeaders = readTestDataMandatoryHeaders();
stateNamesRandomTC4.forEach((state) => {
it('verifyMandatoryHeaderPresent', async () => {
console.log(`Running verifyMandatoryHeaderPresent -> Using sate: ${state}`);
CandidatesPage.load();
await driver.pause(waitTime);
await CandidatesPage.stateSelect.selectByVisibleText(state);
await driver.pause(waitTime);
const actualHeaders = await CandidatesPage.pageHeaders;
const actualHeadersText = [];
await actualHeaders.forEach(async (header) => {
actualHeadersText.push(await header.getText());
});
MandatoryHeaders.forEach((mandatoryHeader) => {
console.log(`Checking if mandatory header '${mandatoryHeader}' is found on the page.`);
assert(actualHeadersText.includes(mandatoryHeader), `Mandatory Header section -> '${mandatoryHeader}' .. not found on the page..`);
});
});
});

// Candidates_005, Candidates_006, Candidates_007, Candidates_008
const stateNamesRandomTC5 = readTestDataStates('random', 3);
stateNamesRandomTC5.forEach((state) => {
const errors = [];
it('verifyCandidateCardHasSectionsDisplayed', async () => {
console.log(`Running verifyCandidateCardHasSectionsDisplayed -> Using sate: ${state}`);
CandidatesPage.load();
await driver.pause(waitTime);
await CandidatesPage.stateSelect.selectByVisibleText(state);
await driver.pause(waitTime);
const candidateCards = await CandidatesPage.CandidateCardList;
for (let i = 0; i < candidateCards.length; i++) {
const card = candidateCards[i];
const cardId = await card.getAttribute('id');
const candidateNameDisplayed = await CandidatesPage.getCandidateCardCandidateName(cardId);
const stateNameDisplayed = await CandidatesPage.getCandidateCardState(cardId);
const partyNameDisplayed = await CandidatesPage.getCandidateCardPartyName(cardId);
const officeNameDisplayed = (await CandidatesPage.getCandidateCardOffice(cardId));
const errMsgNoCandidateName = `Candidate Name not displayed for candidate card: ${cardId}`;
const errMsgNoStateName = `State not displayed for candidate: ${candidateNameDisplayed}`;
const errMsgNoPartyName = `Party not displayed for candidate: ${candidateNameDisplayed}`;
const errMsgNoOfficeName = `Office not displayed for candidate: ${candidateNameDisplayed}`;
if (candidateNameDisplayed === null) errors.push(errMsgNoCandidateName);
if (stateNameDisplayed === null) errors.push(errMsgNoStateName);
if (partyNameDisplayed === null) errors.push(errMsgNoPartyName);
if (officeNameDisplayed === null) errors.push(errMsgNoOfficeName);
}
if (errors.length > 0) {
let errorsAll = '';
for (let i = 0; i < errors.length; i++) {
errorsAll += `${errors[i]}\n`;
}
throw new Error(errorsAll);
}
});
});


// read All Possible Headers from candidatesPage_TC001.json
function readTestDataAllPossibleHeaders () {
const jsonObjH = JSON.parse(fs.readFileSync(`${testDataPath}candidatesPage_TDHeaders.json`));
const possibleHeadersData = jsonObjH.map((i) => i.HeaderText);
return possibleHeadersData;
}
// read Mandatory Headers from candidatesPage_TC001.json
function readTestDataMandatoryHeaders () {
const jsonObjH = JSON.parse(fs.readFileSync(`${testDataPath}candidatesPage_TDHeaders.json`));
const MandatoryHeadersData = (jsonObjH.filter((header) => header.Mandatory === 'Y')).map((i) => i.HeaderText);
return MandatoryHeadersData;
}
// read stateNames from candidatesPage_TDStates.json, return n random states for test run
function readTestDataStates (type, count) {
const jsonObjSt = JSON.parse(fs.readFileSync(`${testDataPath}candidatesPage_TDStates.json`));
const allStateNames = (jsonObjSt[0]).States;
let testStates = [];
if (type === 'all') {
testStates = allStateNames;
} else if (type === 'random') {
for (let cnt = 0; cnt < count; cnt++) {
testStates.push(allStateNames[Math.floor(Math.random() * allStateNames.length)]);
}
}
return testStates;
}
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
[
{
"HeaderText":"Candidates in Close Races",
"Mandatory":"N"
},
{
"HeaderText":"On Your Ballot",
"Mandatory":"N"
},
{
"HeaderText":"More Politicians",
"Mandatory":"Y"
},
{
"HeaderText":"Current Representatives",
"Mandatory":"N"
}
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
[
{
"States":[
"Alabama",
"Alaska",
"Arizona",
"Arkansas",
"California",
"Colorado",
"Connecticut",
"Delaware",
"District of Columbia",
"Florida",
"Georgia",
"Hawaii",
"Idaho",
"Illinois",
"Indiana",
"Iowa",
"Kansas",
"Kentucky",
"Louisiana",
"Maine",
"Maryland",
"Massachusetts",
"Michigan",
"Minnesota",
"Mississippi",
"Missouri",
"Montana",
"Nebraska",
"Nevada",
"New Hampshire",
"New Jersey",
"New Mexico",
"New York",
"North Carolina",
"North Dakota",
"Ohio",
"Oklahoma",
"Oregon",
"Pennsylvania",
"Rhode Island",
"South Carolina",
"South Dakota",
"Tennessee",
"Texas",
"Utah",
"Vermont",
"Virginia",
"Washington",
"West Virginia",
"Wisconsin",
"Wyoming"
]
}
]
Loading