From 348989678e33b16cba7c775bd4167a57d34e1a1c Mon Sep 17 00:00:00 2001
From: GoraJakub <74857860+GoraJakub@users.noreply.github.com>
Date: Sun, 10 Jan 2021 21:58:15 +0100
Subject: [PATCH] [#39] Game Over Modal (#57)
* started creating [#39] Game Result Modal
* added some features
* added middle section to modal
* added bottom section (form) to modal (w/o css)
---
package.json | 2 +-
src/app/App.js | 94 ++++++++++--
src/app/components/isAnswerCorrect.js | 20 +--
src/app/components/mainMenu.js | 4 +-
src/app/components/modalGameOver.js | 173 ++++++++++++++++++++++
src/app/components/ranking.js | 2 +-
src/app/imageRecognizer.js | 20 +--
src/app/logic/playerHuman.js | 26 ++--
styles/App.scss | 1 +
styles/components/gameMode.scss | 28 ++--
styles/components/image.scss | 18 +--
styles/components/modalGameOver.scss | 103 +++++++++++++
styles/components/ranking.scss | 56 +++----
styles/components/redButton.scss | 20 +--
test/app/components/modalGameOver.test.js | 48 ++++++
test/app/logic/playerHuman.test.js | 58 ++++----
test/imageRecognizer.spec.js | 35 +++--
test/isAnswerCorrect.test.js | 34 +++--
test/mainMenu.test.js | 4 +-
19 files changed, 575 insertions(+), 171 deletions(-)
create mode 100644 src/app/components/modalGameOver.js
create mode 100644 styles/components/modalGameOver.scss
create mode 100644 test/app/components/modalGameOver.test.js
diff --git a/package.json b/package.json
index dbd2af0..9209fb0 100644
--- a/package.json
+++ b/package.json
@@ -7,7 +7,7 @@
"clean": "rimraf .cache && rimraf coverage && rimraf dist && rimraf node_modules",
"prebuild": "rimraf dist",
"build": "parcel build index.html --public-url ./",
- "format": "prettier --write \"src/**/*.js\" \"styles/**/*.css\" \"test/**/*.js\"",
+ "format": "prettier --write \"src/**/*.js\" \"styles/**/*.scss\" \"test/**/*.js\"",
"start:dev": "parcel -p 8765 watch index.html",
"test": "jest",
"test:watch": "jest --watch",
diff --git a/src/app/App.js b/src/app/App.js
index ba824eb..f714019 100644
--- a/src/app/App.js
+++ b/src/app/App.js
@@ -1,3 +1,4 @@
+
import { isAnswerCorrect } from './components/isAnswerCorrect'
import { gameMode } from './gameMode'
import { redButton } from './redButton'
@@ -5,18 +6,89 @@ import { imageRecognizer } from './imageRecognizer'
import { mainMenu } from './components/mainMenu'
import { startTime } from './logic/timer'
import { generateQuestion } from './logic/generatingQuestions/generateQuestion'
+import { modalGameOver } from './components/modalGameOver';
+
+const testDataHuman = {
+ q1: {
+ answer: 'Test',
+ correct: 'Test',
+ isCorrect: true,
+ img: '../../static/assets/img/modes/people/1.jpg',
+ },
+ q2: {
+ answer: 'Test',
+ correct: 'Test',
+ isCorrect: true,
+ img: '../../static/assets/img/modes/people/10.jpg',
+ },
+ q3: {
+ answer: 'Test',
+ correct: 'Test',
+ isCorrect: true,
+ img: '../../static/assets/img/modes/people/10.jpg',
+ },
+ q4: {
+ answer: 'Test',
+ correct: 'Test',
+ isCorrect: true,
+ img: '../../static/assets/img/modes/people/10.jpg',
+ },
+ correct: 1,
+ total: 2,
+};
+
+
+const testDataComputer = {
+ q1: {
+ answer: 'Test2',
+ correct: 'Test',
+ isCorrect: false,
+ img: '../../static/assets/img/modes/people/1.jpg',
+ },
+ q2: {
+ answer: 'Test2',
+ correct: 'Test',
+ isCorrect: false,
+ img: '../../static/assets/img/modes/people/10.jpg',
+ },
+ q3: {
+ answer: 'Test',
+ correct: 'Test',
+ isCorrect: true,
+ img: '../../static/assets/img/modes/people/10.jpg',
+ },
+ q4: {
+ answer: 'Test',
+ correct: 'Test',
+ isCorrect: true,
+ img: '../../static/assets/img/modes/people/10.jpg',
+ },
+ correct: 0,
+ total: 2,
+};
-export const App = ({options}) => {
- gameMode('Who is this Character?')
- redButton('play the game');
- imageRecognizer('c3RhdGljL2Fzc2V0cy9pbWcvbW9kZXMvcGVvcGxlLzM2LmpwZw==')
- const getData = (element) => {
- return element;
- };
- mainMenu(document.querySelector('.swquiz-header'), getData);
- startTime(options.quizMaxTime)
- generateQuestion('people').then(res=> console.log(res))
+const getData = (element) => {
+ return element;
+};
-}
+const modalSubmitCallback = (e) => {
+ e.preventDefault();
+ console.log('MAY THE FORCE BE WITH YOU!');
+ document.querySelector('.swquiz-modal').style.display = 'none';
+};
+export const App = ({ options }) => {
+ gameMode('Who is this Character?');
+ redButton('play the game');
+ imageRecognizer('c3RhdGljL2Fzc2V0cy9pbWcvbW9kZXMvcGVvcGxlLzM2LmpwZw==');
+ mainMenu(document.querySelector('.swquiz-header'), getData);
+ modalGameOver(
+ document.querySelector('#swquiz-app'),
+ testDataHuman,
+ testDataComputer,
+ modalSubmitCallback,
+ );
+ startTime(options.quizMaxTime)
+ generateQuestion('people').then(res=> console.log(res))
+};
diff --git a/src/app/components/isAnswerCorrect.js b/src/app/components/isAnswerCorrect.js
index f5bd547..9ee245a 100644
--- a/src/app/components/isAnswerCorrect.js
+++ b/src/app/components/isAnswerCorrect.js
@@ -1,11 +1,11 @@
-const isAnswerCorrect = (guess, answer) =>{
- if(typeof guess !== "string"){
- throw new TypeError("Guessed answer isn't string");
- }
- if(typeof answer !== "string"){
- throw new TypeError("Guessed answer isn't string");
- }
- return guess.toLowerCase() === answer.toLowerCase();
-}
+const isAnswerCorrect = (guess, answer) => {
+ if (typeof guess !== 'string') {
+ throw new TypeError("Guessed answer isn't string");
+ }
+ if (typeof answer !== 'string') {
+ throw new TypeError("Guessed answer isn't string");
+ }
+ return guess.toLowerCase() === answer.toLowerCase();
+};
-export {isAnswerCorrect};
+export { isAnswerCorrect };
diff --git a/src/app/components/mainMenu.js b/src/app/components/mainMenu.js
index 4369998..5a1489c 100644
--- a/src/app/components/mainMenu.js
+++ b/src/app/components/mainMenu.js
@@ -17,10 +17,10 @@ const createButton = (className, textContent, callback) => {
const mainMenu = (parent, callback) => {
if (typeof parent !== 'object') {
- throw new Error("First argument isn't an object!");
+ throw new TypeError("First argument isn't an object!");
}
if (typeof callback !== 'function') {
- throw new Error("Callback argument isn't a function!");
+ throw new TypeError("Callback argument isn't a function!");
}
//Created nav container
diff --git a/src/app/components/modalGameOver.js b/src/app/components/modalGameOver.js
new file mode 100644
index 0000000..6afedb7
--- /dev/null
+++ b/src/app/components/modalGameOver.js
@@ -0,0 +1,173 @@
+const createHeader = (parent, textContent) => {
+ const h1 = document.createElement('h1');
+ h1.textContent = textContent;
+ h1.className = `${parent.className}--header`;
+ parent.appendChild(h1);
+};
+
+const createSummaryP = (parent, playerAnswers, computerAnswers) => {
+ const p = document.createElement('p');
+ p.className = `${parent.className}--paragraph`;
+ p.textContent = `The force is strong in you young Padawan!
+ During 1 minute you have answered ${playerAnswers.correct} / ${playerAnswers.total} questions.
+ And Google quessed ${computerAnswers.correct} / ${computerAnswers.total}.`;
+ parent.appendChild(p);
+};
+
+const createContainer = (parent, classHTML) => {
+ const container = document.createElement('div');
+ container.className = `${parent.className}--${classHTML}`;
+ return container;
+};
+
+const createMidImage = (url, parent) => {
+ const div = document.createElement('div');
+ const img = document.createElement('img');
+ div.className = `${parent.className}--photoContainer`;
+ img.className = `${parent.className}--photo`;
+ img.src = url;
+ img.alt = 'Middle Photo';
+ div.appendChild(img);
+ return div;
+};
+
+const createDetailedAnswerSection = (parent, textContent) => {
+ const div = document.createElement('div');
+ div.className = `${parent.className}--detailedAnswers`;
+ const p = document.createElement('p');
+ p.textContent = textContent;
+ div.appendChild(p);
+ return div;
+};
+
+const isCorrect = (arg) => {
+ return arg ? 'success' : 'danger';
+};
+
+const createDataTable = (parent, playerAnswers, computerAnswers) => {
+ const table = document.createElement('table');
+ const tbody = document.createElement('tbody');
+ table.className = `${parent.className}--table`;
+ const titleRow = `
+ | |
+ You |
+ Computer |
+ Answer |
+ `;
+ table.innerHTML = titleRow;
+ for (let ans in playerAnswers) {
+ if (
+ typeof playerAnswers[ans] === 'object' &&
+ typeof computerAnswers[ans] === 'object'
+ ) {
+ const row = `
+ |
+ ${
+ playerAnswers[ans].answer
+ } |
+ ${
+ computerAnswers[ans].answer
+ } |
+ ${computerAnswers[ans].correct} |
+
`;
+ tbody.innerHTML += row;
+ }
+ }
+ table.appendChild(tbody);
+ return table;
+};
+
+const mergeAndDisplayMiddleSection = (
+ parent,
+ playerAnswers,
+ computerAnswers,
+) => {
+ const container = createContainer(parent, 'middleContainer');
+ const img = createMidImage(
+ '../../../static/assets/ui/MasterYodaLeft.png',
+ parent,
+ );
+ const detailedAnswersSection = createDetailedAnswerSection(
+ parent,
+ 'Detailed answers',
+ );
+ const table = createDataTable(parent, playerAnswers, computerAnswers);
+ container.appendChild(img);
+ detailedAnswersSection.appendChild(table);
+ container.appendChild(detailedAnswersSection);
+
+ parent.appendChild(container);
+};
+
+const createForm = (parent, callback) => {
+ const form = document.createElement('form');
+ form.addEventListener('submit', callback);
+ form.className = `${parent.className}--form`;
+ return form;
+};
+
+const createInput = (parent) => {
+ const input = document.createElement('input');
+ input.className = `${parent.className}--nameInput`;
+ input.id = 'name';
+ input.setAttribute('required', '');
+ return input;
+};
+
+const createLabel = (parent, target) => {
+ const label = document.createElement('label');
+ label.className = `${parent.className}--label`;
+ label.setAttribute('for', target);
+ label.textContent =
+ 'Please fill your name in order to recive eternal glory in whole Galaxy!';
+ return label;
+};
+
+const createButton = (parent) => {
+ const btn = document.createElement('button');
+ btn.className = `${parent.className}--button`;
+ btn.setAttribute('type', 'submit');
+ btn.textContent = 'MAY THE FORCE BE WITH YOU!';
+ return btn;
+};
+
+const mergeAndDisplayBottomSection = (parent, callback) => {
+ const container = createContainer(parent, 'bottomContainer');
+ const form = createForm(parent, callback);
+ const input = createInput(parent);
+ const label = createLabel(parent, input.id);
+ const submitButton = createButton(parent);
+
+ container.appendChild(form);
+ form.appendChild(input);
+ form.appendChild(label);
+ form.appendChild(submitButton);
+
+ parent.appendChild(container);
+};
+
+const modalGameOver = (parent, playerAnswers, computerAnswers, callback) => {
+ if (typeof playerAnswers !== 'object') {
+ throw new TypeError("Second argument isn't an object!");
+ }
+ if (typeof computerAnswers !== 'object') {
+ throw new TypeError("Third argument isn't an object!");
+ }
+ if (typeof callback !== 'function') {
+ throw new TypeError("Fourth argument isn't a function!");
+ }
+ if (typeof parent !== 'object') {
+ throw new TypeError("First argument isn't an object!");
+ }
+ const modal = document.createElement('section');
+ modal.classList.add('swquiz-modal');
+ modal.setAttribute('data-testid', 'gameOverModal');
+
+ parent.appendChild(modal);
+ createHeader(modal, 'Game Over');
+ createSummaryP(modal, playerAnswers, computerAnswers);
+ mergeAndDisplayMiddleSection(modal, playerAnswers, computerAnswers);
+ mergeAndDisplayBottomSection(modal, callback);
+};
+
+export { modalGameOver };
diff --git a/src/app/components/ranking.js b/src/app/components/ranking.js
index 42aa5c1..e71b7d3 100644
--- a/src/app/components/ranking.js
+++ b/src/app/components/ranking.js
@@ -60,7 +60,7 @@ function ranking(scoreList) {
places.forEach((place, index) => {
placeholders.push(createEntry(place, scoreList[index]));
- })
+ });
parent.appendChild(createHeader());
parent.appendChild(createRankingHeader());
diff --git a/src/app/imageRecognizer.js b/src/app/imageRecognizer.js
index 5f0c01f..b806d34 100644
--- a/src/app/imageRecognizer.js
+++ b/src/app/imageRecognizer.js
@@ -1,11 +1,11 @@
export const imageRecognizer = (img) => {
- const app = document.querySelector('#swquiz-app')
- const imageDiv = document.createElement('div')
- //btoa('string') - encode a string
- //function decodes a string of data which has been encoded using Base64 encoding.
- let image = atob(img)
- imageDiv.classList.add('swquiz-app__image')
- imageDiv.setAttribute('data-testid', 'imgRecognizer')
- imageDiv.style.backgroundImage = `url(${image})`
- app.appendChild(imageDiv)
-}
\ No newline at end of file
+ const app = document.querySelector('#swquiz-app');
+ const imageDiv = document.createElement('div');
+ //btoa('string') - encode a string
+ //function decodes a string of data which has been encoded using Base64 encoding.
+ let image = atob(img);
+ imageDiv.classList.add('swquiz-app__image');
+ imageDiv.setAttribute('data-testid', 'imgRecognizer');
+ imageDiv.style.backgroundImage = `url(${image})`;
+ app.appendChild(imageDiv);
+};
diff --git a/src/app/logic/playerHuman.js b/src/app/logic/playerHuman.js
index ab41a15..1778be3 100644
--- a/src/app/logic/playerHuman.js
+++ b/src/app/logic/playerHuman.js
@@ -1,17 +1,17 @@
export class PlayerHuman {
- askQuestion(question, askedQuestion) {
- if(askedQuestion) {
- return askedQuestion(question);
- } else {
- throw new TypeError('Player should get question');
- }
+ askQuestion(question, askedQuestion) {
+ if (askedQuestion) {
+ return askedQuestion(question);
+ } else {
+ throw new TypeError('Player should get question');
}
+ }
- answerOnQuestion(answer, answerdOnQuestion) {
- if(answerdOnQuestion) {
- answerdOnQuestion(answer);
- } else {
- throw new TypeError('Player should answer on asked question');
- }
+ answerOnQuestion(answer, answerdOnQuestion) {
+ if (answerdOnQuestion) {
+ answerdOnQuestion(answer);
+ } else {
+ throw new TypeError('Player should answer on asked question');
}
-}
\ No newline at end of file
+ }
+}
diff --git a/styles/App.scss b/styles/App.scss
index cc7e4d2..b451333 100644
--- a/styles/App.scss
+++ b/styles/App.scss
@@ -3,6 +3,7 @@
@import './components/mainMenu.scss';
@import './components/image.scss';
@import './components/redButton.scss';
+@import './components/modalGameOver.scss';
@import './components/ranking.scss';
@import './components/timeLeftText.scss';
diff --git a/styles/components/gameMode.scss b/styles/components/gameMode.scss
index 81adc56..c8e3e2b 100644
--- a/styles/components/gameMode.scss
+++ b/styles/components/gameMode.scss
@@ -1,14 +1,14 @@
-.question{
- width: 100%;
- background-color: var(--base-white, white);
- color: var(--base-black, black);
- padding: 18px 0px;
- font-weight: 600;
- font-size: 1.5em;
- display: flex;
- justify-content: center;
- border-radius: var(--border-radius, 16px);
- -webkit-box-shadow: var(--box-shadow-property);
- -moz-box-shadow: var(--box-shadow-property);
- box-shadow: var(--box-shadow-property);
-}
\ No newline at end of file
+.question {
+ width: 100%;
+ background-color: var(--base-white, white);
+ color: var(--base-black, black);
+ padding: 18px 0px;
+ font-weight: 600;
+ font-size: 1.5em;
+ display: flex;
+ justify-content: center;
+ border-radius: var(--border-radius, 16px);
+ -webkit-box-shadow: var(--box-shadow-property);
+ -moz-box-shadow: var(--box-shadow-property);
+ box-shadow: var(--box-shadow-property);
+}
diff --git a/styles/components/image.scss b/styles/components/image.scss
index a25e6fc..b5d3e0d 100644
--- a/styles/components/image.scss
+++ b/styles/components/image.scss
@@ -1,10 +1,10 @@
.swquiz-app__image {
- background-repeat: no-repeat;
- background-size: cover;
- width: 400px;
- height: 600px;
- -webkit-box-shadow: var(--box-shadow-property);
- -moz-box-shadow: var(--box-shadow-property);
- box-shadow: var(--box-shadow-property);
- border-radius: var(--border-radius, 16px);
-}
\ No newline at end of file
+ background-repeat: no-repeat;
+ background-size: cover;
+ width: 400px;
+ height: 600px;
+ -webkit-box-shadow: var(--box-shadow-property);
+ -moz-box-shadow: var(--box-shadow-property);
+ box-shadow: var(--box-shadow-property);
+ border-radius: var(--border-radius, 16px);
+}
diff --git a/styles/components/modalGameOver.scss b/styles/components/modalGameOver.scss
new file mode 100644
index 0000000..e147db4
--- /dev/null
+++ b/styles/components/modalGameOver.scss
@@ -0,0 +1,103 @@
+.swquiz-modal {
+ width: 60vw;
+ height: 90vh;
+ background: var(--base-white);
+ border-radius: var(--border-radius);
+ box-shadow: var(--box-shadow-property);
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: space-evenly;
+ font-size: 1.5em;
+ padding: 3vw;
+ &--paragraph {
+ font-weight: 600;
+ }
+
+ &--middleContainer {
+ width: 100%;
+ display: grid;
+ grid-template-columns: 1fr 3fr;
+ max-height: 70%;
+ font-weight: 600;
+ margin-top: 20px;
+ }
+ &--photoContainer {
+ display: flex;
+ justify-content: center;
+ align-items: flex-end;
+ }
+ &--photo {
+ max-height: 300px;
+ }
+ &--detailedAnswers {
+ max-height: 300px;
+ overflow-y: scroll;
+ }
+ &--table {
+ width: 100%;
+ img {
+ max-height: 100px;
+ box-shadow: var(--box-shadow-property);
+ border-radius: var(--border-radius);
+ }
+ tbody {
+ width: 100%;
+ }
+ tr {
+ width: 100%;
+ display: flex;
+ justify-content: space-evenly;
+ margin: 20px 0 20px;
+ td {
+ width: 25%;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ }
+ }
+ }
+ &--form {
+ display: grid;
+ grid-template-columns: 1fr 2fr;
+ grid-template-areas:
+ 'input label'
+ 'button button';
+
+ .swquiz-modal {
+ &--nameInput {
+ grid-area: input;
+ font-size: 1em;
+ border-radius: var(--border-radius);
+ border: 2px solid gray;
+ }
+ &--label {
+ grid-area: label;
+ padding: 5px;
+ font-weight: 600;
+ }
+ &--button {
+ grid-area: button;
+ font-size: 1.2em;
+ width: 70%;
+ height: 6vh;
+ justify-self: center;
+ color: white;
+ border-radius: var(--border-radius);
+ background-color: red;
+ box-shadow: var(--box-shadow-simple), 4px 4px 40px rgba(255, 0, 0, 0.9);
+ margin-top: 3vw;
+ cursor: pointer;
+ border: none;
+ }
+ }
+ }
+}
+
+.success {
+ color: rgb(58, 114, 14);
+}
+
+.danger {
+ color: rgb(159, 6, 6);
+}
diff --git a/styles/components/ranking.scss b/styles/components/ranking.scss
index 8328789..01d69a9 100644
--- a/styles/components/ranking.scss
+++ b/styles/components/ranking.scss
@@ -1,44 +1,44 @@
.ranking-box {
- background-color: white;
- font-size: 1.5rem;
- border-radius: var(--border-radius);
- width: 100%;
- height: 100%;
- padding: 2rem;
- box-shadow: var(--box-shadow-simple);
+ background-color: white;
+ font-size: 1.5rem;
+ border-radius: var(--border-radius);
+ width: 100%;
+ height: 100%;
+ padding: 2rem;
+ box-shadow: var(--box-shadow-simple);
}
.icon-header {
- width: 100%;
- display: flex;
- flex-direction: row;
- justify-content: center;
- align-items: center;
- font-weight: bold;
- font-size: 2rem;
+ width: 100%;
+ display: flex;
+ flex-direction: row;
+ justify-content: center;
+ align-items: center;
+ font-weight: bold;
+ font-size: 2rem;
}
.icon-header > p {
- margin-left: 2rem;
+ margin-left: 2rem;
}
.ranking-row {
- background-color: white;
- grid-column-gap: 10px;
- margin-bottom: 10px;
- display: grid;
- grid-template-columns: 0.15fr 0.7fr 0.15fr;
- grid-template-areas: "place nickname score";
+ background-color: white;
+ grid-column-gap: 10px;
+ margin-bottom: 10px;
+ display: grid;
+ grid-template-columns: 0.15fr 0.7fr 0.15fr;
+ grid-template-areas: 'place nickname score';
}
-.place {
- grid-area: place;
+.place {
+ grid-area: place;
}
-.nickname {
- grid-area: nickname;
+.nickname {
+ grid-area: nickname;
}
-.score {
- grid-area: score;
-}
\ No newline at end of file
+.score {
+ grid-area: score;
+}
diff --git a/styles/components/redButton.scss b/styles/components/redButton.scss
index 93295d3..b53e774 100644
--- a/styles/components/redButton.scss
+++ b/styles/components/redButton.scss
@@ -1,18 +1,18 @@
.button {
- border-radius: 16px;
- font-size: 42px;
- font-weight: 500;
- height: 100px;
- line-height: 51.2px;
- width: 600px;
+ border-radius: 16px;
+ font-size: 42px;
+ font-weight: 500;
+ height: 100px;
+ line-height: 51.2px;
+ width: 600px;
}
.button--red {
- background: rgba(255, 0, 0, 0.8);
- box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
- color: #fff;
+ background: rgba(255, 0, 0, 0.8);
+ box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
+ color: #fff;
}
.button--uppercase {
- text-transform: uppercase;
+ text-transform: uppercase;
}
diff --git a/test/app/components/modalGameOver.test.js b/test/app/components/modalGameOver.test.js
new file mode 100644
index 0000000..c93e6b8
--- /dev/null
+++ b/test/app/components/modalGameOver.test.js
@@ -0,0 +1,48 @@
+import { modalGameOver } from '../../../src/app/components/modalGameOver';
+import { screen } from '@testing-library/dom';
+import '@testing-library/jest-dom/extend-expect';
+
+test('Adding Game over modal to DOM', () => {
+ const callback = () => true;
+ const firstArg = {};
+ const secondArg = {};
+ modalGameOver(document.body, firstArg, secondArg, callback);
+ expect(screen.getByTestId('gameOverModal')).toHaveClass('swquiz-modal');
+ expect(screen.getByTestId('gameOverModal')).toBeInstanceOf(HTMLElement);
+});
+
+test('Throw error when provided invalid first argument', () => {
+ const callback = () => true;
+ const firstArg = {};
+ const secondArg = {};
+ expect(function () {
+ modalGameOver(document.bodysss, firstArg, secondArg, callback);
+ }).toThrow(new TypeError("First argument isn't an object!"));
+});
+
+test('Throw error when provided invalid second argument', () => {
+ const callback = () => true;
+ const secondArg = 3;
+ const thirdArg = {};
+ expect(function () {
+ modalGameOver(document.body, secondArg, thirdArg, callback);
+ }).toThrow(new TypeError("Second argument isn't an object!"));
+});
+
+test('Throw error when provided invalid third argument', () => {
+ const callback = () => true;
+ const secondArg = {};
+ const thirdArg = 3;
+ expect(function () {
+ modalGameOver(document.body, secondArg, thirdArg, callback);
+ }).toThrow(new TypeError("Third argument isn't an object!"));
+});
+
+test('Throw error when provided invalid callback', () => {
+ const callback = 'functiion';
+ const secondArg = {};
+ const thirdArg = {};
+ expect(function () {
+ modalGameOver(document.body, secondArg, thirdArg, callback);
+ }).toThrow(new TypeError("Fourth argument isn't a function!"));
+});
diff --git a/test/app/logic/playerHuman.test.js b/test/app/logic/playerHuman.test.js
index 9cb6274..c001faa 100644
--- a/test/app/logic/playerHuman.test.js
+++ b/test/app/logic/playerHuman.test.js
@@ -1,35 +1,35 @@
import { PlayerHuman } from '../../../src/app/logic/playerHuman';
-describe("playerHuman logic checking", () => {
- const player = new PlayerHuman();
- let question;
- let answer;
+describe('playerHuman logic checking', () => {
+ const player = new PlayerHuman();
+ let question;
+ let answer;
- it("Player got a question, then askedQuestion should be called with question as parameter", () => {
- const askedQuestion = jest.fn();
- player.askQuestion(question, askedQuestion);
- expect(askedQuestion).toBeCalledWith(question);
- });
+ it('Player got a question, then askedQuestion should be called with question as parameter', () => {
+ const askedQuestion = jest.fn();
+ player.askQuestion(question, askedQuestion);
+ expect(askedQuestion).toBeCalledWith(question);
+ });
- it("Player didn't got a question, throw err - Player should get question", () => {
- try {
- expect(player.askQuestion()).toBeCalledWith(question);
- } catch (error) {
- expect(error.message).toBe('Player should get question');
- }
- });
+ it("Player didn't got a question, throw err - Player should get question", () => {
+ try {
+ expect(player.askQuestion()).toBeCalledWith(question);
+ } catch (error) {
+ expect(error.message).toBe('Player should get question');
+ }
+ });
- it("Player should answered on question, then answerdOnQuestion should be called with answer as parameter", () => {
- const answerdOnQuestion = jest.fn();
- player.answerOnQuestion(answer, answerdOnQuestion);
- expect(answerdOnQuestion).toBeCalledWith(answer);
- });
+ it('Player should answered on question, then answerdOnQuestion should be called with answer as parameter', () => {
+ const answerdOnQuestion = jest.fn();
+ player.answerOnQuestion(answer, answerdOnQuestion);
+ expect(answerdOnQuestion).toBeCalledWith(answer);
+ });
- it("Player didn't answered on question, throw err - Player should answer on asked question", () => {
- try {
- expect(player.answerOnQuestion()).toBeCalledWith(answer);
- } catch (error) {
- expect(error.message).toBe('Player should answer on asked question');
- }
- });
-});
\ No newline at end of file
+ it("Player didn't answered on question, throw err - Player should answer on asked question", () => {
+ try {
+ expect(player.answerOnQuestion()).toBeCalledWith(answer);
+ } catch (error) {
+ expect(error.message).toBe('Player should answer on asked question');
+ }
+ });
+});
diff --git a/test/imageRecognizer.spec.js b/test/imageRecognizer.spec.js
index abfd434..f5d212d 100644
--- a/test/imageRecognizer.spec.js
+++ b/test/imageRecognizer.spec.js
@@ -1,26 +1,29 @@
-import {imageRecognizer} from '../src/app/imageRecognizer'
-import { screen } from '@testing-library/dom'
+import { imageRecognizer } from '../src/app/imageRecognizer';
+import { screen } from '@testing-library/dom';
import '@testing-library/jest-dom/extend-expect';
test('Should add div element to DOM, should have class sqwuiz-app__image', () => {
- document.body.innerHTML = `
+ document.body.innerHTML = `
- `
- imageRecognizer('c3RhdGljL2Fzc2V0cy9pbWcvbW9kZXMvcGVvcGxlLzM2LmpwZw==')
+ `;
+ imageRecognizer('c3RhdGljL2Fzc2V0cy9pbWcvbW9kZXMvcGVvcGxlLzM2LmpwZw==');
- expect(screen.getByTestId('imgRecognizer')).toHaveClass('swquiz-app__image')
- expect(screen.getByTestId('imgRecognizer')).toBeInstanceOf(HTMLElement)
-})
+ expect(screen.getByTestId('imgRecognizer')).toHaveClass('swquiz-app__image');
+ expect(screen.getByTestId('imgRecognizer')).toBeInstanceOf(HTMLElement);
+});
test('should be empty div and have background-style', () => {
- document.body.innerHTML = `
+ document.body.innerHTML = `
- `
- imageRecognizer('c3RhdGljL2Fzc2V0cy9pbWcvbW9kZXMvcGVvcGxlLzM2LmpwZw==')
- const imageBas64 = atob('c3RhdGljL2Fzc2V0cy9pbWcvbW9kZXMvcGVvcGxlLzM2LmpwZw==')
- expect(screen.getByTestId('imgRecognizer')).toBeEmptyDOMElement()
- expect(screen.getByTestId('imgRecognizer')).toHaveStyle(`background-image: url('${imageBas64}');`)
-
-})
\ No newline at end of file
+ `;
+ imageRecognizer('c3RhdGljL2Fzc2V0cy9pbWcvbW9kZXMvcGVvcGxlLzM2LmpwZw==');
+ const imageBas64 = atob(
+ 'c3RhdGljL2Fzc2V0cy9pbWcvbW9kZXMvcGVvcGxlLzM2LmpwZw==',
+ );
+ expect(screen.getByTestId('imgRecognizer')).toBeEmptyDOMElement();
+ expect(screen.getByTestId('imgRecognizer')).toHaveStyle(
+ `background-image: url('${imageBas64}');`,
+ );
+});
diff --git a/test/isAnswerCorrect.test.js b/test/isAnswerCorrect.test.js
index ea960cd..0be63b6 100644
--- a/test/isAnswerCorrect.test.js
+++ b/test/isAnswerCorrect.test.js
@@ -1,20 +1,24 @@
-import {isAnswerCorrect} from "../src/app/components/isAnswerCorrect";
+import { isAnswerCorrect } from '../src/app/components/isAnswerCorrect';
import '@testing-library/jest-dom/extend-expect';
-test("Throw error when guessed answer isn't string.",()=>{
- const foo = 2;
- expect(function(){isAnswerCorrect(foo,"answer");}).toThrow(new TypeError("Guessed answer isn't string"));
-})
+test("Throw error when guessed answer isn't string.", () => {
+ const foo = 2;
+ expect(function () {
+ isAnswerCorrect(foo, 'answer');
+ }).toThrow(new TypeError("Guessed answer isn't string"));
+});
-test("Throw error when correct answer isn't string.",()=>{
- const foo = 2;
- expect(function(){isAnswerCorrect("guess",foo);}).toThrow(new TypeError("Guessed answer isn't string"));
-})
+test("Throw error when correct answer isn't string.", () => {
+ const foo = 2;
+ expect(function () {
+ isAnswerCorrect('guess', foo);
+ }).toThrow(new TypeError("Guessed answer isn't string"));
+});
-test("Function return true if answers match.",()=>{
- expect(isAnswerCorrect("correct","correct")).toBe(true);
-})
+test('Function return true if answers match.', () => {
+ expect(isAnswerCorrect('correct', 'correct')).toBe(true);
+});
-test("Function return false if answers match.",()=>{
- expect(isAnswerCorrect("incorrect","correct")).toBe(false);
-})
+test('Function return false if answers match.', () => {
+ expect(isAnswerCorrect('incorrect', 'correct')).toBe(false);
+});
diff --git a/test/mainMenu.test.js b/test/mainMenu.test.js
index 39e713c..3c02af8 100644
--- a/test/mainMenu.test.js
+++ b/test/mainMenu.test.js
@@ -17,11 +17,11 @@ test('Throw error when provided invalid parent argument', () => {
};
expect(function () {
mainMenu(document.bodysss, getData);
- }).toThrow(new Error("First argument isn't an object!"));
+ }).toThrow(new TypeError("First argument isn't an object!"));
});
test('Throw error when provided invalid callback argument', () => {
expect(function () {
mainMenu(document.body, 'getData');
- }).toThrow(new Error("Callback argument isn't a function!"));
+ }).toThrow(new TypeError("Callback argument isn't a function!"));
});