-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path1-naive.test.ts
97 lines (89 loc) · 2.29 KB
/
1-naive.test.ts
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
import { createClient } from "@clickhouse/client";
const ch = createClient({
host: "http://localhost:8123",
database: "segmentation",
clickhouse_settings: {
wait_end_of_query: 1,
},
});
const setup = [
`
CREATE TABLE user_events_naive (
user_id String,
event_name LowCardinality(String),
timestamp DateTime
)
Engine = MergeTree()
ORDER BY (user_id, event_name, timestamp);`,
`
CREATE TABLE segment_assignments_naive (
user_id String,
value Boolean,
assigned_at DateTime DEFAULT now(),
INDEX value_idx value TYPE minmax GRANULARITY 4
)
Engine = ReplacingMergeTree()
ORDER BY (user_id);`,
] as const;
interface NaiveEvent {
user_id: string;
event_name: string;
timestamp: string;
}
describe("using a naive setup", () => {
beforeAll(async () => {
await Promise.all(
setup.map((sql) =>
ch.command({
query: sql,
})
)
);
});
it("calculates segments of users which clicked a button at least 2 times", async () => {
await ch.insert({
table: "user_events_naive (user_id, event_name, timestamp)",
values: [
{
user_id: "1",
event_name: "BUTTON_CLICK",
timestamp: "2023-01-01 00:00:00",
},
{
user_id: "1",
event_name: "BUTTON_CLICK",
timestamp: "2023-01-01 00:05:00",
},
{
user_id: "2",
event_name: "BUTTON_CLICK",
timestamp: "2023-01-01 00:00:00",
},
] satisfies NaiveEvent[],
format: "JSONEachRow",
});
await ch.command({
query: `
INSERT INTO segment_assignments_naive (user_id, value)
SELECT user_id, count() >= 2
FROM user_events_naive
WHERE event_name = 'BUTTON_CLICK'
GROUP BY user_id
`,
});
const segmentsResponse = await ch.query({
query: `
SELECT
user_id,
argMax(value, assigned_at) AS latest_value
FROM segment_assignments_naive
WHERE value = True
GROUP BY user_id;
`,
});
const { data: usersInSegment } = (await segmentsResponse.json()) as {
data: { user_id: string }[];
};
expect(usersInSegment.map((u) => u.user_id)).toEqual(["1"]);
});
});