28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
|
+
+
+
+
+
+
+
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
|
(declare (uses tcp-transportmod))
(declare (uses apimod))
(declare (uses servermod))
(module rmtmod
(
rmtmod:send-receive
rmt:no-sync-get-lock
rmt:no-sync-del!
rmt:no-sync-set
rmt:no-sync-get/default
rmt:get-runs-by-patt
rmt:get-testinfo-state-status
rmt:get-test-id
rmt:set-state-status-and-roll-up-items
)
rmt:get-prereqs-not-met
rmt:get-tests-for-run
rmt:get-keys
rmt:test-get-records-for-index-file
tests:test-set-toplog!
rmt:test-get-logfile-info
rmt:general-call
rmt:test-get-paths-matching-keynames-target-new
rmt:get-test-info-by-id
rmt:get-steps-for-test
rmt:get-num-runs
rmt:get-runs-cnt-by-patt
rmt:get-runs
rmt:get-latest-host-load
rmt:get-changed-record-test-ids
rmt:get-all-runids
rmt:get-changed-record-run-ids
rmt:get-run-record-ids
rmt:get-data-info-by-id
rmt:get-steps-info-by-id
rmt:get-target
rmt:get-run-name-from-id
rmt:get-run-info
rmt:get-test-times
rmt:get-run-times
rmt:tasks-find-task-queue-records
common:api-changed?
rmt:on-homehost?
rmt:get-var
rmt:csv->test-data
rmt:get-previous-test-run-record
common:cleanup-db
common:get-last-run-version
rmt:get-key-val-pairs
rmt:create-all-triggers
rmt:update-tesdata-on-repilcate-db
rmt:drop-all-triggers
rmt:test-get-archive-block-info
rmt:test-toplevel-num-items
rmt:archive-get-allocations
rmt:archive-register-disk
rmt:archive-register-block-name
mt:get-runs-by-patt
rmt:simple-get-runs
rmt:get-tests-for-runs-mindata
rmt:test-get-top-process-pid
rmt:set-state-status-and-roll-up-run
rmt:get-run-state-status
rmt:get-not-completed-cnt
rmt:get-tests-tags
rmt:testmeta-update-field
rmt:testmeta-add-record
rmt:testmeta-get-record
rmt:lock/unlock-run
rmt:delete-old-deleted-test-records
rmt:delete-run
rmt:get-raw-run-stats
rmt:update-run-stats
rmt:delete-test-records
rmt:test-set-archive-block-id
mt:get-tests-for-run
mt:test-set-state-status-by-testname
mt:test-set-state-status-by-testname-unless-completed
rmt:register-test
mt:test-set-state-status-by-id-unless-completed
rmt:get-all-run-ids
rmt:set-run-state-status
rmt:set-var
rmt:set-tests-state-status
rmt:tasks-add
rmt:tasks-set-state-given-param-key
rmt:register-run
rmt:get-count-tests-running-in-jobgroup
rmt:get-count-tests-running-for-run-id
rmt:test-set-state-status-by-id
mt:test-set-state-status-by-id
)
(import scheme
chicken
data-structures
regex
extras
matchable
|
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
|
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
|
-
-
-
-
+
+
+
+
|
(define (rmt:update-run-event_time run-id)
(assert (number? run-id) "FATAL: Run id required.")
(rmt:send-receive 'update-run-event_time #f (list run-id)))
(define (rmt:get-runs-by-patt keys runnamepatt targpatt offset limit fields last-runs-update #!key (sort-order "asc")) ;; fields of #f uses default
(rmt:send-receive 'get-runs-by-patt #f (list keys runnamepatt targpatt offset limit fields last-runs-update sort-order)))
(define (rmt:find-and-mark-incomplete run-id ovr-deadtime)
(assert (number? run-id) "FATAL: Run id required.")
;; (if (rmt:send-receive 'have-incompletes? run-id (list run-id ovr-deadtime))
(rmt:send-receive 'mark-incomplete run-id (list run-id ovr-deadtime))) ;; )
;; (define (rmt:find-and-mark-incomplete run-id ovr-deadtime)
;; (assert (number? run-id) "FATAL: Run id required.")
;; ;; (if (rmt:send-receive 'have-incompletes? run-id (list run-id ovr-deadtime))
;; (rmt:send-receive 'mark-incomplete run-id (list run-id ovr-deadtime))) ;; )
(define (rmt:get-main-run-stats run-id)
(assert (number? run-id) "FATAL: Run id required.")
(rmt:send-receive 'get-main-run-stats #f (list run-id)))
(define (rmt:get-var varname)
(rmt:send-receive 'get-var #f (list varname)))
|
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
|
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
|
-
-
-
-
-
+
+
+
+
+
|
(rmt:send-receive 'add-var #f (list varname value)))
;;======================================================================
;; M U L T I R U N Q U E R I E S
;;======================================================================
;; Need to move this to multi-run section and make associated changes
(define (rmt:find-and-mark-incomplete-all-runs #!key (ovr-deadtime #f))
(let ((run-ids (rmt:get-all-run-ids)))
(for-each (lambda (run-id)
(rmt:find-and-mark-incomplete run-id ovr-deadtime))
run-ids)))
;; (define (rmt:find-and-mark-incomplete-all-runs #!key (ovr-deadtime #f))
;; (let ((run-ids (rmt:get-all-run-ids)))
;; (for-each (lambda (run-id)
;; (rmt:find-and-mark-incomplete run-id ovr-deadtime))
;; run-ids)))
;; get the previous record for when this test was run where all keys match but runname
;; returns #f if no such test found, returns a single test record if found
;;
;; Run this at the client end since we have to connect to multiple run-id dbs
;;
(define (rmt:get-previous-test-run-record run-id test-name item-path)
|