Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
39 commits
Select commit Hold shift + click to select a range
2b5f14c
Require Hello World in the document
acbart Jan 31, 2022
a7dee05
Rename text.Test.tsx to text.test.tsx
acbart Jan 31, 2022
3e381f3
Include the task info
acbart Jan 31, 2022
fee03d3
Merge branch 'task-first-branch' of https://github.com/UD-CISC275-S22…
acbart Jan 31, 2022
e6b1dab
Allow one or more instances of the Hello World text
acbart Feb 3, 2022
7a20734
Include json test command here
acbart Aug 24, 2024
7fe9ca3
Require Hello World in the document
acbart Jan 31, 2022
b8b8878
Include the task info
acbart Jan 31, 2022
fbdebde
Rename text.Test.tsx to text.test.tsx
acbart Jan 31, 2022
2f0146c
Allow one or more instances of the Hello World text
acbart Feb 3, 2022
a6acb43
Merge branch 'task-first-branch' of https://github.com/frontend-fun/t…
acbart Aug 24, 2024
ac36b32
First set of tests
acbart Jan 30, 2022
d04739d
Some logging tests
acbart Jan 30, 2022
b26100f
More html tests
acbart Jan 30, 2022
3bf4550
Fix the image test
acbart Jan 30, 2022
8dff2b6
Updated CSS tests, left a note about additional tests
acbart Jan 31, 2022
b66d4de
See previous commit message
acbart Jan 31, 2022
0a24364
Add in new css test
acbart Aug 24, 2024
4d43d7a
Add in points
acbart Aug 24, 2024
83c4461
Basic functions tests and stubs
acbart Jan 30, 2022
a486530
Fix test organization
acbart Jan 30, 2022
9722564
Fix issue in fahrenheit conversion
acbart Jan 30, 2022
bd06d5d
Move around some of the functions
acbart Feb 3, 2022
4cd1900
Explain what the actual functions require you to do
acbart Feb 3, 2022
cf1d21a
Update formatting
acbart Aug 24, 2024
e11693a
Add in points
acbart Aug 24, 2024
7cc4e3f
First stab at array problems
acbart Feb 1, 2022
f253337
Add in the rest of the tests
acbart Feb 1, 2022
b8777b1
Fix question text
acbart Feb 1, 2022
f87771e
Update arrays.test.ts
acbart Feb 11, 2022
f0d316b
Add in points
acbart Aug 24, 2024
80f1cf6
Update HtmlCss.test.tsx
greglnelson Sep 17, 2024
b594eb6
Added name to App
PlasmaticJewel Sep 13, 2025
00f9787
Added name to App
PlasmaticJewel Sep 13, 2025
5fa8059
Merge remote-tracking branch 'upstream/task-first-branch' into solved…
PlasmaticJewel Sep 13, 2025
1002a27
Added Hello World to App
PlasmaticJewel Sep 13, 2025
642bc78
Merge remote-tracking branch 'upstream/task-html-css' into solved-htm…
PlasmaticJewel Sep 13, 2025
3f66c8b
Merge remote-tracking branch 'upstream/task-functions' into solved-fu…
PlasmaticJewel Sep 13, 2025
f27182f
Merge remote-tracking branch 'upstream/task-arrays' into solved-arrays
PlasmaticJewel Sep 19, 2025
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
123 changes: 57 additions & 66 deletions package-lock.json

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
"build": "react-scripts build",
"test": "react-scripts test",
"test:cov": "react-scripts test --coverage --watchAll",
"test:json": "react-scripts test --json --watchAll=false --outputFile jest-output.json --coverage",
"eject": "react-scripts eject",
"lint": "eslint ./src --ext .tsx --ext .ts --max-warnings 0",
"eslint-output": "eslint-output ./src --ext .tsx --ext .ts --max-warnings 0",
Expand Down
5 changes: 5 additions & 0 deletions public/tasks/task-arrays.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Task - Arrays

Version: 0.0.1

Implement functions that work with arrays immutably.
5 changes: 5 additions & 0 deletions public/tasks/task-first-branch.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Task - First Branch

Version: 0.0.1

Pass a short test to have certain text on the page.
5 changes: 5 additions & 0 deletions public/tasks/task-functions.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Task - Functions

Version: 0.0.1

Implement a bunch of functions that work on primitives.
5 changes: 5 additions & 0 deletions public/tasks/task-html-css.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Task - HTML/CSS

Version: 0.0.1

Add in some HTML and CSS, including a fancy looking button.
2 changes: 1 addition & 1 deletion src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ function App(): React.JSX.Element {
</header>
<p>
Edit <code>src/App.tsx</code> and save. This page will
automatically reload.
automatically reload. Nathan Wheeler Hello World
</p>
</div>
);
Expand Down
83 changes: 83 additions & 0 deletions src/HtmlCss.test.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
import React from "react";
import { render, screen } from "@testing-library/react";
import App from "./App";
import userEvent from "@testing-library/user-event";

describe("Some HTML Elements are added.", () => {
test("(2 pts) There is a heading", () => {
render(<App />);
const heading = screen.getAllByRole("heading");
expect(heading[0]).toBeInTheDocument();
});

test("(2 pts) There is an image with alt text", () => {
render(<App />);
const image = screen.getByRole("img");
expect(image).toBeInTheDocument();
expect(image).toHaveAttribute("alt");
});

test("(2 pts) There is a list with at least three elements", () => {
render(<App />);
const list = screen.getByRole("list");
expect(list).toBeInTheDocument();
expect(list.children.length).toBeGreaterThanOrEqual(3);
});
});

describe("(2 pts) Some basic CSS is added.", () => {
test("The background color of the header area is different", () => {
render(<App />);
const banner = screen.getByRole("banner");
expect(banner).not.toHaveStyle({
"background-color": "rgb(40, 44, 52)",
});
});
});

describe("(2 pts) Some Bootstrap Elements are added", () => {
test("There is one bootstrap button with the text 'Log Hello World'", () => {
render(<App />);
const button = screen.getByRole("button", { name: /Log Hello World/i });
expect(button).toBeInTheDocument();
expect(button).toHaveClass("btn");
expect(button).toHaveClass("btn-primary");
});

test("(2 pts) Not clicking the bootstrap button does not logs 'Hello World!'", () => {
const consoleSpy = jest.spyOn(console, "log");
render(<App />);
expect(consoleSpy).not.toHaveBeenCalledWith("Hello World!");
});

test("(2 pts) Clicking the bootstrap button logs 'Hello World!'", () => {
const consoleSpy = jest.spyOn(console, "log");
render(<App />);
const button = screen.getByRole("button", { name: /Log Hello World/i });
userEvent.click(button);
expect(consoleSpy).toHaveBeenCalledWith("Hello World!");
});
});

describe("Some additional CSS was added", () => {
test("(2 pts) checks if any element has a background color of red", () => {
const { container } = render(<App />);
// Get all elements in the rendered container
const elements = container.querySelectorAll("*");

// Check if any element has a background color of red
let foundRedBackground = false;

elements.forEach((element) => {
const style = getComputedStyle(element);
if (
style.backgroundColor === "red" ||
style.backgroundColor === "rgb(255, 0, 0)"
) {
foundRedBackground = true;
}
});

expect(foundRedBackground).toBe(true);
});
});
273 changes: 273 additions & 0 deletions src/arrays.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,273 @@
import {
allRGB,
bookEndList,
countShortWords,
injectPositive,
makeMath,
removeDollars,
shoutIfExclaiming,
stringsToIntegers,
tripleNumbers,
} from "./arrays";

describe("Testing the array functions", () => {
//////////////////////////////////
// bookEndList and tripleNumbers

const NUMBERS_1 = [1, 2, 3];
const NUMBERS_2 = [100, 300, 200];
const NUMBERS_3 = [5];
const NUMBERS_4: number[] = [];
const NUMBERS_5 = [100, 199, 1, -5, 7, 3];
const NUMBERS_6 = [-100, -200, 100, 200];
const NUMBERS_7 = [199, 1, 550, 50, 200];

// Ensure that none of the arrays were changed mutably
// If you fail these, you aren't using map/filter/reduce/etc. properly!
afterEach(() => {
expect(NUMBERS_1).toEqual([1, 2, 3]);
expect(NUMBERS_2).toEqual([100, 300, 200]);
expect(NUMBERS_3).toEqual([5]);
expect(NUMBERS_4).toEqual([]);
expect(NUMBERS_5).toEqual([100, 199, 1, -5, 7, 3]);
expect(NUMBERS_6).toEqual([-100, -200, 100, 200]);
expect(NUMBERS_7).toEqual([199, 1, 550, 50, 200]);
});

test("(3 pts) Testing the bookEndList function", () => {
expect(bookEndList(NUMBERS_1)).toEqual([1, 3]);
expect(bookEndList(NUMBERS_2)).toEqual([100, 200]);
expect(bookEndList(NUMBERS_3)).toEqual([5, 5]);
expect(bookEndList(NUMBERS_4)).toEqual([]);
expect(bookEndList(NUMBERS_5)).toEqual([100, 3]);
expect(bookEndList(NUMBERS_6)).toEqual([-100, 200]);
});

test("(3 pts) Testing the tripleNumbers function", () => {
expect(tripleNumbers(NUMBERS_1)).toEqual([3, 6, 9]);
expect(tripleNumbers(NUMBERS_2)).toEqual([300, 900, 600]);
expect(tripleNumbers(NUMBERS_3)).toEqual([15]);
expect(tripleNumbers(NUMBERS_4)).toEqual([]);
expect(tripleNumbers(NUMBERS_5)).toEqual([300, 597, 3, -15, 21, 9]);
expect(tripleNumbers(NUMBERS_6)).toEqual([-300, -600, 300, 600]);
});

//////////////////////////////////
// stringsToIntegers

const VALUES_1 = ["1", "2", "3"];
const VALUES_2 = ["100", "200", "300"];
const VALUES_3 = ["5"];
const VALUES_4: string[] = [];
const VALUES_5 = ["100", "?", "27", "$44"];
const VALUES_6 = ["-1", "0", "1", "*1"];
const VALUES_7 = ["apple", "banana", "cactus"];

// Ensure that none of the arrays were changed mutably
// If you fail these, you aren't using map/filter/reduce/etc. properly!
afterEach(() => {
expect(VALUES_1).toEqual(["1", "2", "3"]);
expect(VALUES_2).toEqual(["100", "200", "300"]);
expect(VALUES_3).toEqual(["5"]);
expect(VALUES_4).toEqual([]);
expect(VALUES_5).toEqual(["100", "?", "27", "$44"]);
expect(VALUES_6).toEqual(["-1", "0", "1", "*1"]);
expect(VALUES_7).toEqual(["apple", "banana", "cactus"]);
});

test("(3 pts) Testing the stringsToIntegers function", () => {
expect(stringsToIntegers(VALUES_1)).toEqual([1, 2, 3]);
expect(stringsToIntegers(VALUES_2)).toEqual([100, 200, 300]);
expect(stringsToIntegers(VALUES_3)).toEqual([5]);
expect(stringsToIntegers(VALUES_4)).toEqual([]);
expect(stringsToIntegers(VALUES_5)).toEqual([100, 0, 27, 0]);
expect(stringsToIntegers(VALUES_6)).toEqual([-1, 0, 1, 0]);
expect(stringsToIntegers(VALUES_7)).toEqual([0, 0, 0]);
});

//////////////////////////////////
// removeDollars

const AMOUNTS_1 = ["$1", "$2", "$3"];
const AMOUNTS_2 = ["$100", "$200", "$300", "$400"];
const AMOUNTS_3 = ["$5"];
const AMOUNTS_4 = ["$"];
const AMOUNTS_5 = ["100", "200", "$300", "$400"];
const AMOUNTS_6: string[] = [];
const AMOUNTS_7 = ["100", "???", "7", "$233", "", "$"];
const AMOUNTS_8 = ["$one", "two", "$three"];

// Ensure that none of the arrays were changed mutably
// If you fail these, you aren't using map/filter/reduce/etc. properly!
afterEach(() => {
expect(AMOUNTS_1).toEqual(["$1", "$2", "$3"]);
expect(AMOUNTS_2).toEqual(["$100", "$200", "$300", "$400"]);
expect(AMOUNTS_3).toEqual(["$5"]);
expect(AMOUNTS_4).toEqual(["$"]);
expect(AMOUNTS_5).toEqual(["100", "200", "$300", "$400"]);
expect(AMOUNTS_6).toEqual([]);
expect(AMOUNTS_7).toEqual(["100", "???", "7", "$233", "", "$"]);
expect(AMOUNTS_8).toEqual(["$one", "two", "$three"]);
});

test("(3 pts) Testing the removeDollars function", () => {
expect(removeDollars(AMOUNTS_1)).toEqual([1, 2, 3]);
expect(removeDollars(AMOUNTS_2)).toEqual([100, 200, 300, 400]);
expect(removeDollars(AMOUNTS_3)).toEqual([5]);
expect(removeDollars(AMOUNTS_4)).toEqual([0]);
expect(removeDollars(AMOUNTS_5)).toEqual([100, 200, 300, 400]);
expect(removeDollars(AMOUNTS_6)).toEqual([]);
expect(removeDollars(AMOUNTS_7)).toEqual([100, 0, 7, 233, 0, 0]);
expect(removeDollars(AMOUNTS_8)).toEqual([0, 0, 0]);
});

//////////////////////////////////
// shoutIfExclaiming

const MESSAGE_1 = ["Hello", "you", "are", "great!"];
const MESSAGE_2 = ["oho!", "Oho!", "oHo!", "oHO!", "OHO!"];
const MESSAGE_3 = ["Wait?", "What?", "Lo", "How?", "High!"];
const MESSAGE_4 = ["??????"];
const MESSAGE_5: string[] = ["This one is very long!"];
const MESSAGE_6 = ["No", "Caps", "here.", "Right?"];

// Ensure that none of the arrays were changed mutably
// If you fail these, you aren't using map/filter/reduce/etc. properly!
afterEach(() => {
expect(MESSAGE_1).toEqual(["Hello", "you", "are", "great!"]);
expect(MESSAGE_2).toEqual(["oho!", "Oho!", "oHo!", "oHO!", "OHO!"]);
expect(MESSAGE_3).toEqual(["Wait?", "What?", "Lo", "How?", "High!"]);
expect(MESSAGE_4).toEqual(["??????"]);
expect(MESSAGE_5).toEqual(["This one is very long!"]);
expect(MESSAGE_6).toEqual(["No", "Caps", "here.", "Right?"]);
});

test("(3 pts) Testing the shoutIfExclaiming function", () => {
expect(shoutIfExclaiming(MESSAGE_1)).toEqual([
"Hello",
"you",
"are",
"GREAT!",
]);
expect(shoutIfExclaiming(MESSAGE_2)).toEqual([
"OHO!",
"OHO!",
"OHO!",
"OHO!",
"OHO!",
]);
expect(shoutIfExclaiming(MESSAGE_3)).toEqual(["Lo", "HIGH!"]);
expect(shoutIfExclaiming(MESSAGE_4)).toEqual([]);
expect(shoutIfExclaiming(MESSAGE_5)).toEqual([
"THIS ONE IS VERY LONG!",
]);
expect(shoutIfExclaiming(MESSAGE_6)).toEqual(["No", "Caps", "here."]);
});

//////////////////////////////////
// countShortWords

const WORDS_1 = ["the", "cat", "in", "the", "hat"];
const WORDS_2 = ["one", "two", "three", "four", "five", "six", "seven"];
const WORDS_3 = ["alpha", "beta", "gamma"];
const WORDS_4 = ["Longest", "Words", "Possible"];
const WORDS_5: string[] = [];
const WORDS_6 = ["", "", "", ""];

// Ensure that none of the arrays were changed mutably
// If you fail these, you aren't using map/filter/reduce/etc. properly!
afterEach(() => {
expect(WORDS_1).toEqual(["the", "cat", "in", "the", "hat"]);
expect(WORDS_2).toEqual([
"one",
"two",
"three",
"four",
"five",
"six",
"seven",
]);
expect(WORDS_3).toEqual(["alpha", "beta", "gamma"]);
expect(WORDS_4).toEqual(["Longest", "Words", "Possible"]);
expect(WORDS_5).toEqual([]);
expect(WORDS_6).toEqual(["", "", "", ""]);
});

test("(3 pts) Testing the countShortWords function", () => {
expect(countShortWords(WORDS_1)).toEqual(5);
expect(countShortWords(WORDS_2)).toEqual(3);
expect(countShortWords(WORDS_3)).toEqual(0);
expect(countShortWords(WORDS_4)).toEqual(0);
expect(countShortWords(WORDS_5)).toEqual(0);
expect(countShortWords(WORDS_6)).toEqual(4);
});

//////////////////////////////////
// allRGB

const COLORS_1 = ["red", "green", "blue"];
const COLORS_2 = ["red", "red", "red"];
const COLORS_3 = ["red", "red", "blue", "blue", "green", "red"];
const COLORS_4 = ["purple", "orange", "violet"];
const COLORS_5 = ["red", "blue", "yellow"];
const COLORS_6 = ["green"];
const COLORS_7 = ["red"];
const COLORS_8 = ["kabluey"];
const COLORS_9: string[] = [];

// Ensure that none of the arrays were changed mutably
// If you fail these, you aren't using map/filter/reduce/etc. properly!
afterEach(() => {
expect(COLORS_1).toEqual(["red", "green", "blue"]);
expect(COLORS_2).toEqual(["red", "red", "red"]);
expect(COLORS_3).toEqual([
"red",
"red",
"blue",
"blue",
"green",
"red",
]);
expect(COLORS_4).toEqual(["purple", "orange", "violet"]);
expect(COLORS_5).toEqual(["red", "blue", "yellow"]);
expect(COLORS_6).toEqual(["green"]);
expect(COLORS_7).toEqual(["red"]);
expect(COLORS_8).toEqual(["kabluey"]);
expect(COLORS_9).toEqual([]);
});

test("(3 pts) Testing the allRGB function", () => {
expect(allRGB(COLORS_1)).toEqual(true);
expect(allRGB(COLORS_2)).toEqual(true);
expect(allRGB(COLORS_3)).toEqual(true);
expect(allRGB(COLORS_4)).toEqual(false);
expect(allRGB(COLORS_5)).toEqual(false);
expect(allRGB(COLORS_6)).toEqual(true);
expect(allRGB(COLORS_7)).toEqual(true);
expect(allRGB(COLORS_8)).toEqual(false);
expect(allRGB(COLORS_9)).toEqual(true);
});

//////////////////////////////////
// makeMath

test("(3 pts) Testing the makeMath function", () => {
expect(makeMath(NUMBERS_1)).toEqual("6=1+2+3");
expect(makeMath(NUMBERS_2)).toEqual("600=100+300+200");
expect(makeMath(NUMBERS_3)).toEqual("5=5");
expect(makeMath(NUMBERS_4)).toEqual("0=0");
expect(makeMath(NUMBERS_7)).toEqual("1000=199+1+550+50+200");
});

//////////////////////////////////
// injectPositive
test("(3 pts) Testing the injectPositive function", () => {
expect(injectPositive(NUMBERS_1)).toEqual([1, 2, 3, 6]);
expect(injectPositive(NUMBERS_2)).toEqual([100, 300, 200, 600]);
expect(injectPositive(NUMBERS_3)).toEqual([5, 5]);
expect(injectPositive(NUMBERS_4)).toEqual([0]);
expect(injectPositive(NUMBERS_5)).toEqual([100, 199, 1, -5, 300, 7, 3]);
expect(injectPositive(NUMBERS_6)).toEqual([-100, 0, -200, 100, 200]);
expect(injectPositive(NUMBERS_7)).toEqual([199, 1, 550, 50, 200, 1000]);
});
});
Loading