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("/")
def read_root():
def read_root(mock: bool = False):
return {
'sladovnicka': getMenuSladovnicka(),
'uMotliku:': getMenuUMotliku(),
'techTower': getMenuTechTower()
'sladovnicka': getMenuSladovnicka(mock),
# TODO opravit dvojtečku!
'uMotliku:': getMenuUMotliku(mock),
'techTower': getMenuTechTower(mock)
}

View File

@ -96,7 +96,14 @@ def printMenu(name: str, foodList: List[Food]):
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)
soup = BeautifulSoup(html, "html.parser")
div = soup.select_one("div.tab-pane.fade.in.active")
@ -137,7 +144,14 @@ def getMenuSladovnicka() -> List[Food]:
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)
soup = BeautifulSoup(html, "html.parser")
table = soup.find("table", {"class": "Xtable-striped"})
@ -175,7 +189,13 @@ def getMenuUMotliku() -> List[Food]:
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)
soup = BeautifulSoup(html, "html.parser")
fonts = soup.find_all("font", {"class": ["wsw-41"]})
@ -189,7 +209,7 @@ def getMenuTechTower() -> List[Food]:
siblings = font.parent.parent.find_next_siblings("p")
# dayNumber = date.today().strftime("%w")
currentDayName = getDayNameOfDate(datetime.datetime.now())
foodList = []
foodList: List[Food] = []
doParse = False
for i in range(0, len(siblings)):
text = siblings[i].text.strip().replace('\t', '').replace('\n', ' ')

View File

@ -1,3 +1,4 @@
export NODE_ENV=development
./food_api/run_dev.sh &
cd server && 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": {
"cheerio": "^1.0.0-rc.12",
"cors": "^2.8.5",
"dotenv": "^16.1.3",
"express": "^4.18.2",
"request": "^2.88.2",
"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!
export const fetchFood = async () => {
try {
const json = await rp(foodUrl);
const json = await rp({ uri: foodUrl, qs: { "mock": process.env.MOCK_DATA } });
return JSON.parse(json);
} catch (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 cors from 'cors';
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 server = require("http").createServer(app);

View File

@ -1,7 +1,7 @@
import { ClientData, Locations } from "./types";
import { db } from "./database";
import { getHumanDate, getIsWeekend } from "./utils";
import { getDate } from "./utils";
import { formatDate } from "./utils";
// /** Jedna konkrétní 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
// }
/** 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. */
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.
*/
export function getData(): ClientData {
const data = db.get(getDate()) || getEmptyData();
console.log("Vracím data pro dnešní den", data); // TODO smazat
const data = db.get(formatDate(getToday())) || getEmptyData();
return data;
}
@ -70,7 +77,7 @@ export function getData(): ClientData {
// }
export function initIfNeeded() {
const today = getDate();
const today = formatDate(getToday());
if (!db.has(today)) {
db.set(today, getEmptyData());
}
@ -91,7 +98,7 @@ export function removeChoice(login: string, data: ClientData) {
export function updateChoice(login: string, choice: Locations | null) {
initIfNeeded();
const today = getDate();
const today = formatDate(getToday());
let data: ClientData = db.get(today);
data = removeChoice(login, data);
if (choice !== null) {

View File

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

View File

@ -465,6 +465,11 @@ domutils@^3.0.1:
domelementtype "^2.3.0"
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:
version "0.1.2"
resolved "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz"