Skip to content

Commit

Permalink
Merge pull request #8 from x-image-privacy/3-unit-test
Browse files Browse the repository at this point in the history
Unit test
  • Loading branch information
RoxaneBurri authored Mar 15, 2023
2 parents 7d925a3 + d6292a5 commit d8c931d
Show file tree
Hide file tree
Showing 5 changed files with 321 additions and 218 deletions.
32 changes: 4 additions & 28 deletions src/App.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,8 @@
import "./App.css";
import {
futurPosition,
getArea,
getBoundingRect,
placeWordOnOuterCircle,
Word,
} from "./utils";
import * as React from "react";
import {
Expand All @@ -14,32 +12,15 @@ import {
CONTAINER_WIDTH,
DEFAULT_RECT,
} from "./constants";
import { defaultWords1 } from "./data";

const CUT_OFF = 0.5;

export const MAX_FONT_SIZE = 20;
export const MIN_FONT_SIZE = 6;

const defaultWords: Word[] = [
{ id: "word-1", text: " Big word ", coef: 0.99 },
{ id: "word-2", text: "hello", coef: 0.8 },
{ id: "word-4", text: "caramba", coef: 0.97 },
{ id: "word-3", text: "all", coef: 0.74 },
{ id: "word-5", text: "Piniata", coef: 0.6 },
{ id: "word-6", text: "Taxi", coef: 0.93 },
{ id: "word-7", text: "papa", coef: 0.94 },
{ id: "word-8", text: "chicita", coef: 0.66 },
{ id: "word-9", text: "hellicopter", coef: 0.92 },
{ id: "word-10", text: "chiold", coef: 0.75 },
{ id: "word-11", text: "text", coef: 0.81 },
{ id: "word-12", text: "document", coef: 0.77 },
{ id: "word-13", text: "text", coef: 0.89 },
{ id: "word-14", text: "finger", coef: 0.91 },
{ id: "word-15", text: "girl", coef: 0.88 },
];

const Wordcloud = () => {
const [words, setWords] = React.useState(defaultWords);
const [words, setWords] = React.useState(defaultWords1);

const updateWords = () => {
setWords((prevWords) => {
Expand All @@ -57,21 +38,16 @@ const Wordcloud = () => {
const newPositions = rectsToPlace.slice(1).reduce(
(placedElements, rect) => {
// move the word
const futureWord = futurPosition(
// put the word in random place around the parent
placeWordOnOuterCircle(rect),
placedElements,
3
);
const futureWord = futurPosition(rect, placedElements, 3);
return [...placedElements, futureWord];
},
[centeredRect]
);

return wordsToPlace.map((word, idx) => ({
...word,
rect: newPositions[idx],
}));

});
};

Expand Down
121 changes: 121 additions & 0 deletions src/data.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
import { Word } from "./utils";

export const defaultWords1: Word[] = [
{ id: "word-1", text: " Big word ", coef: 0.99 },
{ id: "word-2", text: "hello", coef: 0.8 },
{ id: "word-4", text: "caramba", coef: 0.97 },
{ id: "word-3", text: "all", coef: 0.74 },
{ id: "word-5", text: "Piniata", coef: 0.6 },
{ id: "word-6", text: "Taxi", coef: 0.93 },
{ id: "word-7", text: "papa", coef: 0.94 },
{ id: "word-8", text: "chicita", coef: 0.66 },
{ id: "word-9", text: "hellicopter", coef: 0.92 },
{ id: "word-10", text: "chiold", coef: 0.75 },
{ id: "word-11", text: "text", coef: 0.81 },
{ id: "word-12", text: "document", coef: 0.77 },
{ id: "word-13", text: "text", coef: 0.89 },
{ id: "word-14", text: "finger", coef: 0.91 },
{ id: "word-15", text: "girl", coef: 0.88 },
];
export const defaultWords2: Word[] = [
{ id: "word-1", text: "group", coef: 0.99 },
{ id: "word-2", text: "people", coef: 0.99 },
{ id: "word-4", text: "adult", coef: 0.98 },
{ id: "word-3", text: "man", coef: 0.97 },
{ id: "word-5", text: "woman", coef: 0.96 },
{ id: "word-6", text: "room", coef: 0.95 },
{ id: "word-7", text: "indoors", coef: 0.94 },
{ id: "word-8", text: "group together", coef: 0.92 },
{ id: "word-9", text: "facial expression", coef: 0.92 },
{ id: "word-10", text: "wear", coef: 0.92 },
{ id: "word-11", text: "meeting", coef: 0.89 },
{ id: "word-12", text: "several", coef: 0.86 },
{ id: "word-13", text: "exhibition", coef: 0.85 },
{ id: "word-14", text: "education", coef: 0.84 },
{ id: "word-15", text: "religion", coef: 0.83 },
{ id: "word-16", text: "award", coef: 0.82 },
{ id: "word-17", text: "portrait", coef: 0.8 },
{ id: "word-18", text: "happiness", coef: 0.8 },
{ id: "word-19", text: "school", coef: 0.8 },
{ id: "word-20", text: "league", coef: 0.79 },
{ id: "word-21", text: "five", coef: 0.79 },
{ id: "word-22", text: "celebration", coef: 0.79 },
{ id: "word-23", text: "four", coef: 0.78 },
{ id: "word-24", text: "business", coef: 0.78 },
{ id: "word-25", text: "furniture", coef: 0.77 },
{ id: "word-26", text: "leader", coef: 0.77 },
{ id: "word-27", text: "festival", coef: 0.77 },
{ id: "word-28", text: "commerce", coef: 0.76 },
{ id: "word-29", text: "many", coef: 0.75 },
{ id: "word-30", text: "outfit", coef: 0.74 },
{ id: "word-31", text: "chair", coef: 0.74 },
{ id: "word-32", text: "girl", coef: 0.73 },
{ id: "word-34", text: "administration", coef: 0.73 },
{ id: "word-33", text: "boy", coef: 0.72 },
{ id: "word-35", text: "wedding", coef: 0.71 },
{ id: "word-36", text: "child", coef: 0.71 },
{ id: "word-37", text: "daylight", coef: 0.71 },
{ id: "word-38", text: "music", coef: 0.71 },
{ id: "word-39", text: "container", coef: 0.71 },
{ id: "word-40", text: "employee", coef: 0.71 },
{ id: "word-41", text: "three", coef: 0.7 },
{ id: "word-42", text: "family", coef: 0.7 },
{ id: "word-44", text: "office", coef: 0.7 },
{ id: "word-43", text: "cooperation", coef: 0.69 },
{ id: "word-45", text: "museum", coef: 0.68 },
{ id: "word-46", text: "travel", coef: 0.68 },
{ id: "word-47", text: "singer", coef: 0.66 },
{ id: "word-48", text: "performance", coef: 0.65 },
{ id: "word-49", text: "vehicle", coef: 0.65 },
{ id: "word-50", text: "event", coef: 0.64 },
{ id: "word-51", text: "ceremony", coef: 0.63 },
{ id: "word-52", text: "musician", coef: 0.63 },
{ id: "word-54", text: "enjoyment", coef: 0.63 },
{ id: "word-53", text: "recreation", coef: 0.61 },
{ id: "word-55", text: "prosperity", coef: 0.61 },
{ id: "word-56", text: "landscape", coef: 0.61 },
{ id: "word-57", text: "teamwork", coef: 0.6 },
{ id: "word-58", text: "gown", coef: 0.59 },
{ id: "word-59", text: "city", coef: 0.59 },
{ id: "word-60", text: "university", coef: 0.59 },
{ id: "word-61", text: "table", coef: 0.58 },
{ id: "word-62", text: "soccer", coef: 0.57 },
{ id: "word-64", text: "home", coef: 0.57 },
{ id: "word-63", text: "hotel", coef: 0.56 },
{ id: "word-65", text: "movie", coef: 0.55 },
{ id: "word-66", text: "food", coef: 0.55 },
{ id: "word-67", text: "band", coef: 0.54 },
{ id: "word-68", text: "aircraft", coef: 0.54 },
{ id: "word-69", text: "presentation", coef: 0.53 },
{ id: "word-70", text: "military", coef: 0.53 },
{ id: "word-71", text: "parliament", coef: 0.52 },
{ id: "word-72", text: "queue", coef: 0.52 },
{ id: "word-74", text: "competition", coef: 0.51 },
{ id: "word-73", text: "guest", coef: 0.51 },
{ id: "word-75", text: "graduation", coef: 0.5 },
{ id: "word-76", text: "crowd", coef: 0.5 },
{ id: "word-77", text: "actor", coef: 0.5 },
{ id: "word-78", text: "politician", coef: 0.49 },
{ id: "word-79", text: "planning", coef: 0.49 },
{ id: "word-80", text: "airport", coef: 0.49 },
{ id: "word-81", text: "adolescent", coef: 0.49 },
{ id: "word-82", text: "tie", coef: 0.49 },
{ id: "word-84", text: "uniform", coef: 0.48 },
{ id: "word-83", text: "interaction", coef: 0.48 },
{ id: "word-85", text: "authority", coef: 0.48 },
{ id: "word-86", text: "drink", coef: 0.48 },
{ id: "word-87", text: "coffee", coef: 0.48 },
{ id: "word-88", text: "friendship", coef: 0.47 },
{ id: "word-89", text: "street", coef: 0.47 },
{ id: "word-90", text: "election", coef: 0.46 },
{ id: "word-91", text: "convention", coef: 0.46 },
{ id: "word-92", text: "democracy", coef: 0.45 },
{ id: "word-94", text: "gold", coef: 0.45 },
{ id: "word-93", text: "partnership", coef: 0.45 },
{ id: "word-95", text: "football", coef: 0.45 },
{ id: "word-96", text: "document", coef: 0.44 },
{ id: "word-97", text: "audience", coef: 0.44 },
{ id: "word-98", text: "public show", coef: 0.44 },
{ id: "word-99", text: "popularity", coef: 0.44 },
{ id: "word-100", text: "seat", coef: 0.44 },
];
146 changes: 145 additions & 1 deletion src/utils.test.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,26 @@
import { describe, expect, it } from "vitest";
import { areCentersTooClose, Coordinate, Rectangle } from "./utils";
import {
areCentersTooClose,
Coordinate,
allCollision,
Rectangle,
getMoveDirection,
getTheCircle,
getDistance,
} from "./utils";

const origin: Coordinate = {
x: 0,
y: 0,
};

const originRectangle: Rectangle = {
x: 0,
y: 0,
width: 1,
height: 1,
};

describe("areCentersTooClose", () => {
it("No collisions", () => {
expect(areCentersTooClose(origin, { x: 6, y: 0 }, 2, 2)).toBe(false);
Expand All @@ -28,3 +43,132 @@ describe("areCentersTooClose", () => {
expect(areCentersTooClose({ x: -2, y: -2 }, origin, 2.5, 2.5)).toBe(true);
});
});

describe("Get move direction", () => {
it("1 rectangle", () => {
expect(
getMoveDirection([{ x: 4, y: 6, width: 4, height: 4 }], {
x: 3,
y: 4,
width: 3,
height: 3,
})
).toEqual({ x: 1, y: 2 });
});

it("2 rectangles", () => {
expect(
getMoveDirection(
[
{ x: 4, y: 6, width: 4, height: 4 },
{ x: 8, y: 5, width: 7, height: 7 },
],
{ x: 3, y: 4, width: 3, height: 3 }
)
).toEqual({
x: 6,
y: 3,
});
});

it("Negative coordinate", () => {
expect(
getMoveDirection([{ x: -4, y: -6, width: 4, height: 4 }], {
x: 3,
y: -4,
width: 3,
height: 3,
})
).toEqual({
x: -7,
y: -2,
});
});

it("Same coordinate", () => {
expect(
getMoveDirection([{ x: 0, y: 0, width: 4, height: 4 }], {
x: 0,
y: 0,
width: 3,
height: 3,
})
).toEqual({
x: 0,
y: 0,
});
});
});

describe("All collision", () => {
it("Collision with self", () => {
expect(allCollision(originRectangle, [originRectangle])).toBe(true);
});

it("No collision with 2 rectangles", () => {
expect(
allCollision(originRectangle, [{ x: 4, y: 4, width: 2, height: 2 }])
).toBe(false);
});

it("Collision with 2 rectangles", () => {
expect(
allCollision(originRectangle, [
{ x: 2, y: 2, width: 4, height: 4 },
{ x: 6, y: 6, width: 2, height: 2 },
])
).toBe(true);
});
});

describe("Get distance", () => {
it("Naive test", () => {
expect(
getDistance({ x: 1, y: 1 }, { x: 1, y: 1, width: 4, height: 4 })
).toEqual(0);
});

it("Naive test", () => {
expect(
getDistance({ x: 10, y: 5 }, { x: 1, y: 5, width: 4, height: 4 })
).toEqual(9);
});
});

describe("Get the circle", () => {
it("Center of mass one word", () => {
expect(getTheCircle([{ x: 1, y: 1, width: 4, height: 4 }])).toEqual({
x: 1,
y: 1,
radius: 250,
});
});

it("Center of mass multiple words", () => {
expect(
getTheCircle([
{ x: 1, y: 1, width: 4, height: 4 },
{ x: 3, y: 4, width: 4, height: 4 },
{ x: 2, y: 2, width: 4, height: 4 },
{ x: -2, y: 1, width: 4, height: 4 },
])
).toEqual({
x: 1,
y: 2,
radius: 250,
});
});

it("Center of mass update radius", () => {
expect(
getTheCircle([
{ x: 0, y: 0, width: 4, height: 4 },
{ x: 600, y: 0, width: 4, height: 4 },
])
).toEqual({
x: 300,
y: 0,
radius: 300,
});
});
});
Loading

0 comments on commit d8c931d

Please sign in to comment.