2023-12-19 16:59:23 +01:00
|
|
|
#!/bin/node
|
|
|
|
const { createApp, getTable, createRow, createTable } = require("./utils")
|
|
|
|
|
2023-12-20 11:51:35 +01:00
|
|
|
const Chance = require("chance")
|
|
|
|
const generator = new Chance()
|
|
|
|
|
2023-12-20 13:04:16 +01:00
|
|
|
const STUDENT_COUNT = 500
|
2023-12-20 12:18:29 +01:00
|
|
|
const SUBJECT_COUNT = 10
|
2023-12-19 16:59:23 +01:00
|
|
|
|
|
|
|
if (!process.argv[2]) {
|
|
|
|
console.error("Please specify an API key as script argument.")
|
|
|
|
process.exit(-1)
|
|
|
|
}
|
|
|
|
|
2023-12-20 13:04:16 +01:00
|
|
|
const start = Date.now()
|
|
|
|
|
2023-12-19 16:59:23 +01:00
|
|
|
async function run() {
|
|
|
|
const apiKey = process.argv[2]
|
|
|
|
const app = await createApp(apiKey)
|
2023-12-20 12:30:35 +01:00
|
|
|
console.log(`App created: http://localhost:10000/builder/app/${app._id}`)
|
|
|
|
|
2023-12-20 12:18:29 +01:00
|
|
|
const studentsTable = await getTable(apiKey, app._id)
|
|
|
|
if (studentsTable.name !== "Students") {
|
|
|
|
throw 'Fetched table should be "Students"'
|
|
|
|
}
|
|
|
|
console.log(`Table found: ${studentsTable.name}`)
|
2023-12-19 16:59:23 +01:00
|
|
|
|
2023-12-20 12:52:25 +01:00
|
|
|
const students = [],
|
|
|
|
subjects = []
|
|
|
|
|
|
|
|
let studentNumber = studentsTable.schema["Auto ID"].lastID
|
|
|
|
for (let i = 0; i < STUDENT_COUNT; i++) {
|
|
|
|
students.push(
|
|
|
|
await createRow(apiKey, app._id, studentsTable, {
|
|
|
|
"Student Number": (++studentNumber).toString(),
|
|
|
|
"First Name": generator.first(),
|
|
|
|
"Last Name": generator.last(),
|
|
|
|
Gender: generator.pickone(["M", "F"]),
|
|
|
|
Grade: generator.pickone(["8", "9", "10", "11"]),
|
|
|
|
"Tardiness (Days)": generator.integer({ min: 1, max: 100 }),
|
|
|
|
"Home Number": generator.phone(),
|
|
|
|
"Attendance_(%)": generator.integer({ min: 0, max: 100 }),
|
|
|
|
})
|
|
|
|
)
|
2023-12-20 13:04:16 +01:00
|
|
|
console.log(
|
|
|
|
`Student ${i + 1} of ${STUDENT_COUNT} created (${
|
|
|
|
(Date.now() - start) / 1000
|
|
|
|
}s)`
|
|
|
|
)
|
2023-12-20 12:52:25 +01:00
|
|
|
}
|
|
|
|
|
2023-12-19 16:59:23 +01:00
|
|
|
const subjectTable = await createTable(apiKey, app._id, {
|
|
|
|
schema: {
|
2023-12-20 11:51:35 +01:00
|
|
|
Name: {
|
2023-12-19 16:59:23 +01:00
|
|
|
name: "Name",
|
|
|
|
type: "string",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
name: "Subjects",
|
2023-12-20 12:52:25 +01:00
|
|
|
primaryDisplay: "Name",
|
2023-12-19 16:59:23 +01:00
|
|
|
})
|
2023-12-20 11:51:35 +01:00
|
|
|
|
|
|
|
for (let i = 0; i < SUBJECT_COUNT; i++) {
|
2023-12-20 12:52:25 +01:00
|
|
|
subjects.push(
|
2023-12-20 13:04:16 +01:00
|
|
|
await createRow(apiKey, app._id, subjectTable, {
|
|
|
|
Name: generator.profession(),
|
|
|
|
})
|
|
|
|
)
|
|
|
|
console.log(
|
|
|
|
`Subject ${i + 1} of ${SUBJECT_COUNT} created (${
|
|
|
|
(Date.now() - start) / 1000
|
|
|
|
}s)`
|
2023-12-20 12:52:25 +01:00
|
|
|
)
|
2023-12-19 16:59:23 +01:00
|
|
|
}
|
|
|
|
|
2023-12-20 12:52:25 +01:00
|
|
|
const gradesTable = await createTable(apiKey, app._id, {
|
|
|
|
schema: {
|
|
|
|
Score: {
|
|
|
|
name: "Score",
|
|
|
|
type: "number",
|
|
|
|
},
|
|
|
|
Student: {
|
|
|
|
name: "Student",
|
|
|
|
tableId: studentsTable._id,
|
|
|
|
constraints: {
|
|
|
|
presence: true,
|
|
|
|
type: "array",
|
|
|
|
},
|
|
|
|
fieldName: "Grades",
|
|
|
|
relationshipType: "one-to-many",
|
|
|
|
type: "link",
|
|
|
|
},
|
|
|
|
Subject: {
|
|
|
|
name: "Subject",
|
|
|
|
tableId: subjectTable._id,
|
|
|
|
constraints: {
|
|
|
|
presence: true,
|
|
|
|
type: "array",
|
|
|
|
},
|
|
|
|
fieldName: "Grades",
|
|
|
|
relationshipType: "one-to-many",
|
|
|
|
type: "link",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
name: "Grades",
|
|
|
|
})
|
|
|
|
|
|
|
|
let i = 0
|
|
|
|
for (const student of students) {
|
|
|
|
for (const subject of subjects) {
|
|
|
|
await createRow(apiKey, app._id, gradesTable, {
|
|
|
|
Score: generator.integer({ min: 0, max: 100 }),
|
|
|
|
Student: [student],
|
|
|
|
Subject: [subject],
|
2023-12-20 13:04:16 +01:00
|
|
|
})
|
2023-12-20 12:52:25 +01:00
|
|
|
console.log(
|
2023-12-20 13:04:16 +01:00
|
|
|
`Grade ${++i} of ${students.length * subjects.length} created (${
|
|
|
|
(Date.now() - start) / 1000
|
|
|
|
}s)`
|
2023-12-20 12:52:25 +01:00
|
|
|
)
|
|
|
|
}
|
2023-12-19 16:59:23 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-12-20 13:04:16 +01:00
|
|
|
run()
|
|
|
|
.then(() => {
|
|
|
|
console.log(`Done in(${(Date.now() - start) / 1000} seconds`)
|
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
console.error(err)
|
|
|
|
})
|