-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.ts
More file actions
51 lines (42 loc) · 1.69 KB
/
index.ts
File metadata and controls
51 lines (42 loc) · 1.69 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import { mergeRequestEvents, NewMergeRequestEvent, MergeRequest } from "./tables";
import { type ExtractTablesWithRelations, eq } from "drizzle-orm";
import { createClient, type ResultSet } from "@libsql/client";
import { type SQLiteTransaction } from "drizzle-orm/sqlite-core";
import { drizzle } from "drizzle-orm/libsql";
if (!process.argv[2]) {
}
const no = parseInt(process.argv[2], 10) || 56;
console.warn("-------------------------------------");
console.warn("Inserting", no, "merge request events");
console.warn("-------------------------------------");
function deleteMergeRequestEvents(tx: SQLiteTransaction<"async", ResultSet, Record<string, unknown>, ExtractTablesWithRelations<Record<string, unknown>>>, mergeRequestId: MergeRequest["id"]) {
return tx.delete(mergeRequestEvents)
.where(
eq(mergeRequestEvents.mergeRequest, mergeRequestId)
);
}
function insertMergeRequestEvents(
tx: SQLiteTransaction<"async", ResultSet, Record<string, unknown>, ExtractTablesWithRelations<Record<string, unknown>>>,
mre: NewMergeRequestEvent[]) {
return tx.insert(mergeRequestEvents)
.values(mre);
}
const db = drizzle(createClient({
url: process.env.TURSO_URL!,
authToken: process.env.TURSO_AUTH_TOKEN!
}));
const exampleMergeRequestEvent = {
actor: 1,
commitedAt: 1,
mergeRequest: 1,
mergeRequestEventType: "noted",
occuredOn: 1,
repository: 1,
reviewState: "unknown",
subject: 1,
timestamp: new Date("2006-01-02T15:04:05-07:00"),
} satisfies NewMergeRequestEvent
await db.transaction(async tx => {
await deleteMergeRequestEvents(tx, exampleMergeRequestEvent.mergeRequest).run();
await insertMergeRequestEvents(tx, new Array(no).fill(exampleMergeRequestEvent)).run();
});