Podpora mock dat pro vývoj o víkendech

This commit is contained in:
Martin Berka 2023-06-03 09:24:36 +02:00
parent b438d2112a
commit c814624dbc
10 changed files with 58 additions and 17 deletions

View File

@ -12,9 +12,10 @@ app.add_middleware(
) )
@app.get("/") @app.get("/")
def read_root(): def read_root(mock: bool = False):
return { return {
'sladovnicka': getMenuSladovnicka(), 'sladovnicka': getMenuSladovnicka(mock),
'uMotliku:': getMenuUMotliku(), # TODO opravit dvojtečku!
'techTower': getMenuTechTower() 'uMotliku:': getMenuUMotliku(mock),
'techTower': getMenuTechTower(mock)
} }

View File

@ -96,7 +96,14 @@ def printMenu(name: str, foodList: List[Food]):
print('\n') print('\n')
def getMenuSladovnicka() -> List[Food]: def getMenuSladovnicka(mock: bool = False) -> List[Food]:
if mock:
foodList: List[Food] = []
foodList.append(Food("Zelná polévka s klobásou", "0,25l", "35 Kč", True))
foodList.append(Food("Hovězí na česneku s bramborovým knedlíkem", "150g", "135 Kč"))
foodList.append(Food("Přírodní holandský řízek s bramborovou kaší, rajčatový salát", "250g", "135 Kč"))
foodList.append(Food("Bagel s vinnou klobásou, cibulový konfit, kysané zelí, slanina a hořčicová mayo, hranolky, curry omáčka", "350g", "135 Kč"))
return foodList
html = getOrDownloadHtml('sladovnicka', URL_SLADOVNICKA) html = getOrDownloadHtml('sladovnicka', URL_SLADOVNICKA)
soup = BeautifulSoup(html, "html.parser") soup = BeautifulSoup(html, "html.parser")
div = soup.select_one("div.tab-pane.fade.in.active") div = soup.select_one("div.tab-pane.fade.in.active")
@ -137,7 +144,14 @@ def getMenuSladovnicka() -> List[Food]:
return foodList return foodList
def getMenuUMotliku() -> List[Food]: def getMenuUMotliku(mock: bool = False) -> List[Food]:
if mock:
foodList: List[Food] = []
foodList.append(Food("Hovězí vývar s nudlemi", "0,33l", "35 Kč", True))
foodList.append(Food("Opečený párek, čočka, sázené vejce, okurka", "150g", "135 Kč"))
foodList.append(Food("Hovězí líčka na červeném víně, bramborová kaše", "150g", "145 Kč"))
foodList.append(Food("Tortilla s trhaným kuřecím masem, uzeným sýrem, dipem a kukuřicí, míchaný salát", "150g", "135 Kč"))
return foodList
html = getOrDownloadHtml('u_motliku', URL_MOTLICI) html = getOrDownloadHtml('u_motliku', URL_MOTLICI)
soup = BeautifulSoup(html, "html.parser") soup = BeautifulSoup(html, "html.parser")
table = soup.find("table", {"class": "Xtable-striped"}) table = soup.find("table", {"class": "Xtable-striped"})
@ -175,7 +189,13 @@ def getMenuUMotliku() -> List[Food]:
return foodList return foodList
def getMenuTechTower() -> List[Food]: def getMenuTechTower(mock: bool = False) -> List[Food]:
if mock:
foodList: List[Food] = []
foodList.append(Food("Bavorská gulášová polévka s kroupami", "-", "40 Kč", True))
foodList.append(Food("Vepřové výpečky, kedlubnové zelí, bramborový knedlík", "-", "120 Kč"))
foodList.append(Food("Hambuger Black Angus s čedarem a slaninou, cibulové kroužky", "-", "220 Kč"))
return foodList
html = getOrDownloadHtml('techtower', URL_TECHTOWER) html = getOrDownloadHtml('techtower', URL_TECHTOWER)
soup = BeautifulSoup(html, "html.parser") soup = BeautifulSoup(html, "html.parser")
fonts = soup.find_all("font", {"class": ["wsw-41"]}) fonts = soup.find_all("font", {"class": ["wsw-41"]})
@ -189,7 +209,7 @@ def getMenuTechTower() -> List[Food]:
siblings = font.parent.parent.find_next_siblings("p") siblings = font.parent.parent.find_next_siblings("p")
# dayNumber = date.today().strftime("%w") # dayNumber = date.today().strftime("%w")
currentDayName = getDayNameOfDate(datetime.datetime.now()) currentDayName = getDayNameOfDate(datetime.datetime.now())
foodList = [] foodList: List[Food] = []
doParse = False doParse = False
for i in range(0, len(siblings)): for i in range(0, len(siblings)):
text = siblings[i].text.strip().replace('\t', '').replace('\n', ' ') text = siblings[i].text.strip().replace('\t', '').replace('\n', ' ')

View File

@ -1,3 +1,4 @@
export NODE_ENV=development
./food_api/run_dev.sh & ./food_api/run_dev.sh &
cd server && yarn install && yarn start & cd server && yarn install && yarn start &
cd client && yarn install && yarn start & cd client && yarn install && yarn start &

1
server/.env.development Normal file
View File

@ -0,0 +1 @@
MOCK_DATA=true

View File

@ -18,6 +18,7 @@
"dependencies": { "dependencies": {
"cheerio": "^1.0.0-rc.12", "cheerio": "^1.0.0-rc.12",
"cors": "^2.8.5", "cors": "^2.8.5",
"dotenv": "^16.1.3",
"express": "^4.18.2", "express": "^4.18.2",
"request": "^2.88.2", "request": "^2.88.2",
"request-promise": "^4.2.6", "request-promise": "^4.2.6",

View File

@ -110,7 +110,7 @@ export const fetchPizzy = async () => {
// TODO tohle sem absolutně nepatří! dát do vlastní servisky! // TODO tohle sem absolutně nepatří! dát do vlastní servisky!
export const fetchFood = async () => { export const fetchFood = async () => {
try { try {
const json = await rp(foodUrl); const json = await rp({ uri: foodUrl, qs: { "mock": process.env.MOCK_DATA } });
return JSON.parse(json); return JSON.parse(json);
} catch (error) { } catch (error) {
console.error("Chyba při volání Food API", error); console.error("Chyba při volání Food API", error);

View File

@ -4,6 +4,11 @@ import bodyParser from "body-parser";
import { fetchFood, fetchPizzy } from "./chefie"; import { fetchFood, fetchPizzy } from "./chefie";
import cors from 'cors'; import cors from 'cors';
import { getData, updateChoice } from "./service"; import { getData, updateChoice } from "./service";
import dotenv from 'dotenv';
import path from 'path';
const ENVIRONMENT = process.env.NODE_ENV || 'production'
dotenv.config({ path: path.resolve(__dirname, `../.env.${ENVIRONMENT}`) });
const app = express(); const app = express();
const server = require("http").createServer(app); const server = require("http").createServer(app);

View File

@ -1,7 +1,7 @@
import { ClientData, Locations } from "./types"; import { ClientData, Locations } from "./types";
import { db } from "./database"; import { db } from "./database";
import { getHumanDate, getIsWeekend } from "./utils"; import { getHumanDate, getIsWeekend } from "./utils";
import { getDate } from "./utils"; import { formatDate } from "./utils";
// /** Jedna konkrétní pizza */ // /** Jedna konkrétní pizza */
// interface Pizza { // interface Pizza {
@ -31,17 +31,24 @@ import { getDate } from "./utils";
// orders?: Order[], // seznam objednávek, pokud není vyplněno, není založen pizza day // orders?: Order[], // seznam objednávek, pokud není vyplněno, není založen pizza day
// } // }
/** Vrátí dnešní datum, případně fiktivní datum pro účely vývoje a testování. */
function getToday(): Date {
if (process.env.MOCK_DATA) {
return new Date('2023-05-31');
}
return new Date();
}
/** Vrátí "prázdná" (implicitní) data, pokud ještě nikdo nehlasoval. */ /** Vrátí "prázdná" (implicitní) data, pokud ještě nikdo nehlasoval. */
function getEmptyData(): ClientData { function getEmptyData(): ClientData {
return { date: getHumanDate(new Date()), isWeekend: getIsWeekend(new Date()), choices: {} }; return { date: getHumanDate(getToday()), isWeekend: getIsWeekend(getToday()), choices: {} };
} }
/** /**
* Vrátí veškerá klientská data pro aktuální den. * Vrátí veškerá klientská data pro aktuální den.
*/ */
export function getData(): ClientData { export function getData(): ClientData {
const data = db.get(getDate()) || getEmptyData(); const data = db.get(formatDate(getToday())) || getEmptyData();
console.log("Vracím data pro dnešní den", data); // TODO smazat
return data; return data;
} }
@ -70,7 +77,7 @@ export function getData(): ClientData {
// } // }
export function initIfNeeded() { export function initIfNeeded() {
const today = getDate(); const today = formatDate(getToday());
if (!db.has(today)) { if (!db.has(today)) {
db.set(today, getEmptyData()); db.set(today, getEmptyData());
} }
@ -91,7 +98,7 @@ export function removeChoice(login: string, data: ClientData) {
export function updateChoice(login: string, choice: Locations | null) { export function updateChoice(login: string, choice: Locations | null) {
initIfNeeded(); initIfNeeded();
const today = getDate(); const today = formatDate(getToday());
let data: ClientData = db.get(today); let data: ClientData = db.get(today);
data = removeChoice(login, data); data = removeChoice(login, data);
if (choice !== null) { if (choice !== null) {

View File

@ -1,5 +1,5 @@
export function getDate() { /** Vrátí datum v ISO formátu. */
const date = new Date(); export function formatDate(date: Date) {
let currentDay = String(date.getDate()).padStart(2, '0'); let currentDay = String(date.getDate()).padStart(2, '0');
let currentMonth = String(date.getMonth() + 1).padStart(2, "0"); let currentMonth = String(date.getMonth() + 1).padStart(2, "0");
let currentYear = date.getFullYear(); let currentYear = date.getFullYear();

View File

@ -465,6 +465,11 @@ domutils@^3.0.1:
domelementtype "^2.3.0" domelementtype "^2.3.0"
domhandler "^5.0.1" domhandler "^5.0.1"
dotenv@^16.1.3:
version "16.1.3"
resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-16.1.3.tgz#0c67e90d0ddb48d08c570888f709b41844928210"
integrity sha512-FYssxsmCTtKL72fGBSvb1K9dRz0/VZeWqFme/vSb7r7323x4CRaHu4LvQ5JG3+s6yt2YPbBrkpiEODktfyjI9A==
ecc-jsbn@~0.1.1: ecc-jsbn@~0.1.1:
version "0.1.2" version "0.1.2"
resolved "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz" resolved "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz"