-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcalculate_flakiness_jobs.sql
63 lines (60 loc) · 2.08 KB
/
calculate_flakiness_jobs.sql
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
/*
This query returns the failure percentage of a list of jobs that have failed
at least once in the last @param2@ days with the @param1@ test failure.
Input parameters:
param1: error name
param2: time period (e.g.: 7 days)
param3 (optional): job name filter
Output columns:
job_name,
last_fail,
first_fail,
build_count,
failure_count,
failure_percentage
Usage:
./sql_run.sh calculate_flakiness_jobs.sql projectroot.test_rosbag2_play_end_to_end "30 days"
*/
WITH recent_builds AS (
SELECT job_name,
COUNT(*) build_count
FROM build_status
WHERE build_datetime >= DATE('now', '-@param2@')
AND build_status.status IN ("SUCCESS", "UNSTABLE")
GROUP BY job_name
),
recent_failures AS (
SELECT build_status.job_name,
COUNT(DISTINCT build_status.build_number) failure_count,
MAX(build_status.build_datetime) last_failure_datetime,
MIN(build_status.build_datetime) first_failure_datetime
FROM build_status,
test_failures
WHERE build_status.build_number = test_failures.build_number
AND build_status.job_name = test_failures.job_name
AND build_status.status IN ("SUCCESS", "UNSTABLE")
AND build_status.build_datetime >= DATE('now', '-@param2@')
AND test_failures.error_name LIKE '@param1@'
GROUP BY build_status.job_name
)
SELECT build_status.job_name,
DATE(recent_failures.last_failure_datetime) last_fail,
DATE(recent_failures.first_failure_datetime) first_fail,
recent_builds.build_count,
recent_failures.failure_count,
ROUND(
CAST(recent_failures.failure_count AS FLOAT) / recent_builds.build_count * 100,
2
) AS failure_percentage,
server_status.project,
server_status.domain
FROM build_status,
recent_builds,
recent_failures
INNER JOIN server_status ON server_status.job_name = build_status.job_name
WHERE recent_builds.job_name = build_status.job_name
AND recent_failures.job_name = build_status.job_name
AND recent_failures.failure_count > 0
AND build_status.job_name LIKE "%@param3@%"
GROUP BY build_status.job_name
ORDER BY last_fail DESC;