-
Notifications
You must be signed in to change notification settings - Fork 0
/
codegrade_menu.test.js
178 lines (146 loc) · 8.34 KB
/
codegrade_menu.test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
import { fireEvent, getByText } from '@testing-library/dom';
import '@testing-library/jest-dom/extend-expect';
import { JSDOM } from 'jsdom';
import fs from 'fs';
import path from 'path';
import { fail } from 'assert';
const html = fs.readFileSync(path.resolve(__dirname, './menu.html'), 'utf8');
let dom;
let container;
describe('menu.html', () => {
beforeEach(() => {
// Constructing a new JSDOM with this option is the key
// to getting the code in the script tag to execute.
// This is indeed dangerous and should only be done with trusted content.
// https://github.com/jsdom/jsdom#executing-scripts
dom = new JSDOM(html, { runScripts: 'dangerously' });
container = dom.window.document.body;
});
it('renders with an external stylesheet', () => {
const cssLinkTag = dom.window.document.head.querySelector('link[href="css/menu.css"]');
expect(cssLinkTag).toBeInTheDocument();
});
it('has a viewport tag', () => {
const viewportTag = dom.window.document.head.querySelector('meta[content="width=device-width, initial-scale=1.0"]');
expect(viewportTag).toBeInTheDocument();
});
it('renders a header title that links to home page', () => {
const headerTitle = container.querySelector('h1').innerHTML;
const headerTitleATag = container.querySelector('header a');
const regex = /BLOOMTECH BAR AND GRILL/i;
expect(headerTitle).toMatch(regex);
expect(headerTitleATag.href.includes('index.html')).toEqual(true);
});
it('renders the correct four links in header nav links div', () => {
const headerNavLinks = container.querySelector('header nav div');
let headerNavLinkTextArr = headerNavLinks.innerHTML.split(/<a /i);
// shift is to get rid of initial index that splits before the a tag
headerNavLinkTextArr.shift();
expect(headerNavLinkTextArr.length).toBe(4);
expect(getByText(headerNavLinks, /Menu/i)).toBeInTheDocument();
expect(getByText(headerNavLinks, /Reservations/i)).toBeInTheDocument();
expect(getByText(headerNavLinks, /Special Offers/i)).toBeInTheDocument();
expect(getByText(headerNavLinks, /Contact/i)).toBeInTheDocument();
});
it('header menu link correctly links to new page', async () => {
const menuLink = container.querySelector('header nav a');
expect(menuLink.href.includes('menu.html')).toEqual(true);
});
it('renders the correct three social media icons in header nav', () => {
const headerNavLinks = container.querySelector('nav');
let headerSMIconsArr = headerNavLinks.innerHTML.split(/<i /i);
// shift is to get rid of initial index that splits before the i tag
headerSMIconsArr.shift();
expect(headerSMIconsArr.length).toBe(3);
for (let i = 0; i < headerSMIconsArr.length; i++) {
const index = headerSMIconsArr[i];
if(index.includes('facebook')) {
expect(index.includes('facebook')).toBe(true);
} else if(index.includes('twitter')) {
expect(index.includes('twitter')).toBe(true);
} else if(index.includes('instagram')) {
expect(index.includes('instagram')).toBe(true);
} else fail(`Hit an unexpected icon tag`);
}
});
it('renders a menu title', () => {
const menuTitle = container.querySelector('h2').innerHTML;
const regex = /Food & Drink/i;
expect(menuTitle).toMatch(regex);
});
it('renders five menu-section class sections with proper titles in correct order', () => {
const menuSections = Array.from(container.querySelectorAll('.menu-section'));
expect(menuSections.length).toBe(5);
for(let i = 0; i < menuSections.length; i++) {
if(menuSections[i].innerHTML.includes('Drinks')) {
expect(getByText(menuSections[0], /Drinks/i)).toBeInTheDocument();
} else if(menuSections[i].innerHTML.includes('Appetizers')) {
expect(getByText(menuSections[1], /Appetizers/i)).toBeInTheDocument();
} else if(menuSections[i].innerHTML.includes('Soup and Salad')) {
expect(getByText(menuSections[2], /Soup and Salad/i)).toBeInTheDocument();
} else if(menuSections[i].innerHTML.includes('Entrees')) {
expect(getByText(menuSections[3], /Entrees/i)).toBeInTheDocument();
} else if(menuSections[i].innerHTML.includes('Desserts')) {
expect(getByText(menuSections[4], /Desserts/i)).toBeInTheDocument();
} else fail(`Inappropriate menu section name`);
}
});
it('renders three to five menu-items per menu-section', () => {
const menuSections = Array.from(container.querySelectorAll('.menu-section'));
if(menuSections === undefined || menuSections === null || menuSections.length === 0) fail(`Inappropriate number of menu sections.`);
menuSections.forEach((section) => {
const menuItems = Array.from(section.querySelectorAll('.menu-item'));
if(menuItems === undefined || menuSections === null || menuSections.length === 0) fail(`Inappropriate number of menu items.`);
if(menuItems.length >= 3 && menuItems.length <= 5) {
expect(menuItems.length >= 3 && menuItems.length <= 5).toBe(true);
} else fail(`Inappropriate number of menu items.`);
});
});
it('renders an h4 for name and price per each menu-item', () => {
const menuSections = Array.from(container.querySelectorAll('.menu-section'));
if(menuSections === undefined || menuSections === null || menuSections.length === 0) fail(`Inappropriate number of menu sections.`);
menuSections.forEach((section) => {
const menuItems = Array.from(section.querySelectorAll('.menu-item'));
if(menuItems === undefined || menuSections === null || menuSections.length === 0) fail(`Inappropriate number of menu items.`);
menuItems.forEach((item) => {
let itemsh4Count = item.innerHTML.match(/<h4/gi).length;
expect(itemsh4Count).toBe(2);
});
});
});
it('renders a p for description and optional V/GF label per each menu-item', () => {
const menuSections = Array.from(container.querySelectorAll('.menu-section'));
if(menuSections === undefined || menuSections === null || menuSections.length === 0) fail(`Inappropriate number of menu sections.`);
menuSections.forEach((section) => {
const menuItems = Array.from(section.querySelectorAll('.menu-item'));
if(menuItems === undefined || menuSections === null || menuSections.length === 0) fail(`Inappropriate number of menu items.`);
menuItems.forEach((item) => {
let itemsPCount = item.innerHTML.match(/<p/gi).length;
expect(itemsPCount === 1 || itemsPCount === 2).toBe(true);
});
});
});
it('renders an input and button in footer nav with appropriate text', () => {
const footerInput = container.querySelector('footer input');
const footerButton = container.querySelector('footer button');
expect(footerInput).not.toBe(null || undefined);
expect(footerInput.placeholder.includes('Email Address')).toBe(true);
expect(footerButton).not.toBe(null || undefined);
expect(footerButton.innerHTML.includes('Sign Up')).toBe(true);
});
it('renders the correct four links in footer nav', () => {
const footerNavLinks = container.querySelector('footer nav');
let footerNavLinkTextArr = footerNavLinks.innerHTML.split(/<a /i);
// shift is to get rid of initial index that splits before the a tag
footerNavLinkTextArr.shift();
expect(footerNavLinkTextArr.length).toBe(4);
expect(getByText(footerNavLinks, /Menu/i)).toBeInTheDocument();
expect(getByText(footerNavLinks, /Reservations/i)).toBeInTheDocument();
expect(getByText(footerNavLinks, /Special Offers/i)).toBeInTheDocument();
expect(getByText(footerNavLinks, /Contact/i)).toBeInTheDocument();
});
it('footer menu link correctly links to new page', async () => {
const menuLink = container.querySelector('footer nav a');
expect(menuLink.href.includes('menu.html')).toEqual(true);
});
});