diff options
author | Joel Kronqvist <work.joelkronqvist@gmail.com> | 2022-10-18 21:41:31 +0300 |
---|---|---|
committer | Joel Kronqvist <work.joelkronqvist@gmail.com> | 2022-10-18 21:41:31 +0300 |
commit | c28fe49a7a303ef0440ccffd830e4949a1f2381f (patch) | |
tree | 802cf959381c9d4bcc5b1ce9fabd8d8a524ff834 | |
parent | 82eb5ff8594db3b0382be812253f4dae3f06425f (diff) | |
download | LYLLRuoka-c28fe49a7a303ef0440ccffd830e4949a1f2381f.tar.gz LYLLRuoka-c28fe49a7a303ef0440ccffd830e4949a1f2381f.zip |
Enhanced robustness in retrieving the example input and in the init (at reboot) script.
The server errored out if the database was empty and there came a request, as it didn't check for empty arrays in dbparse.js in the function getRandomIndex. Fixed by adding handling & recursion limit. Added in init.sh a check to see if logging in to MySQL is possible to prevent errors at startup.
-rw-r--r-- | dbparse.js | 10 | ||||
-rwxr-xr-x | init.sh | 8 | ||||
-rw-r--r-- | server.js | 2 |
3 files changed, 17 insertions, 3 deletions
@@ -173,10 +173,14 @@ function randInt(start, stop) return start + Math.floor(Math.random() * (stop - start)); } -async function getRandomIndex(day, DB) +async function getRandomIndex(day, DB, depth=0) { + if (depth > 10) + return null; + let indexes = await DB.execute("SELECT course, teacher, class FROM shifts WHERE day = ? ORDER BY RAND() LIMIT 1", [day]); - indexes = Object.values(indexes[0]); + + indexes = Object.values(indexes[0] || [null, null, null]); /// ERROR HERE!!! let start = randInt(0, indexes.length); for (let test = 0; test < 3; test++) { @@ -185,7 +189,7 @@ async function getRandomIndex(day, DB) return indexes[i]; } console.log("Warning: row without class/teacher/course in database!"); - return getRandomIndex(day, DB); + return getRandomIndex(day, DB, depth + 1); } @@ -13,6 +13,14 @@ echo "# Connected to internet!" echo "" +echo "# Testing DB availability" +while ! echo 'exit' | mysql; do + sleep 5 +done +echo "# Database seems to be available (ignore error messages above)" + +echo "" + cd "$BASE_DIR/LYLLRuoka" echo "# node server.js:" node server.js @@ -252,6 +252,8 @@ async function buildMain(args) // get the example input res["example-input"] = await DBPARSE.randomIndex(day, SQLDB); + if (res["example-input"] === null) + res["example-input"] = ""; // get the day let weekdays = ["ma", "ti", "ke", "to", "pe", "la", "su"]; |