Overview
Comment: | Most changes in place to fix sorting in dashboard |
---|---|
Downloads: | Tarball | ZIP archive | SQL archive |
Timelines: | family | ancestors | descendants | both | v1.55 |
Files: | files | file ages | folders |
SHA1: |
1a9a9bcf2350e01a966ad45fd2daa814 |
User & Date: | matt on 2013-08-19 00:53:06 |
Other Links: | branch diff | manifest | tags |
Context
2013-08-19
| ||
09:47 | Merged in missing fix check-in: be405e8e2e user: mrwellan tags: v1.55 | |
00:53 | Most changes in place to fix sorting in dashboard check-in: 1a9a9bcf23 user: matt tags: v1.55 | |
2013-08-18
| ||
22:03 | Better support for read-only access to a Megatest area check-in: 439da33084 user: matt tags: v1.55 | |
Changes
Modified dashboard.scm from [caac9567a8] to [1cd65f8047].
︙ | |||
136 137 138 139 140 141 142 | 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 | + + + + + + + + + + - + | (define *examine-test-dat* (make-hash-table)) (define *exit-started* #f) (define *status-ignore-hash* (make-hash-table)) (define *state-ignore-hash* (make-hash-table)) (define *db-file-path* (conc *toppath* "/megatest.db")) (define *tests-sort-options* (vector (vector "Sort +a" 'testname "ASC") (vector "Sort -a" 'testname "DESC") (vector "Sort +t" 'event_time "ASC") (vector "Sort -t" 'event_time "DESC"))) (define (next-sort-option) (if (>= *tests-sort-reverse* 3) (set! *tests-sort-reverse* 0) (set! *tests-sort-reverse* (+ *tests-sort-reverse* 1))) *tests-sort-reverse*) |
︙ | |||
193 194 195 196 197 198 199 | 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 | - - + + + + + - - + | (maxtests 0) (states (hash-table-keys *state-ignore-hash*)) (statuses (hash-table-keys *status-ignore-hash*))) ;; ;; trim runs to only those that are changing often here ;; (for-each (lambda (run) |
︙ | |||
266 267 268 269 270 271 272 | 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 | - - + + + + + + + + + + + + + + + + + + + - + + | (vlst (run-item-name->vectors newlst)) ;; sort by second field (vlst-s1 (sort vlst (lambda (a b) (let ((astr (vector-ref a 1)) (bstr (vector-ref b 1))) (if (string=? astr "") #f #t))))) ;; (>= (string-length (vector-ref a 1))(string-length (vector-ref b 1)))))) |
︙ | |||
299 300 301 302 303 304 305 306 307 308 309 310 311 312 | 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 | + + + + + + + + + + + + + + + + + + + + + + + + | (let ((munged-val (let ((parts (string-split newval "("))) (if (> (length parts) 1)(conc " " (car (string-split (cadr parts) ")"))) newval)))) (vector-set! keycol i newval) (iup:attribute-set! lbl "TITLE" munged-val))) (iup:attribute-set! lbl "FGCOLOR" (if (hash-table-ref/default *collapsed* newval #f) "0 112 112" "0 0 0")) (if (< i maxn) (loop (+ i 1))))))) ;; ;; inlst is list of vectors < testname itempath > ;; ;; ;; (define (bubble-up inlst) ;; (let ((tnames (delete-duplicates (map (lambda (x)(vector-ref x 0)) inlst)))) ;; (if (null? inlst) ;; inlst ;; (let loop ((hed (car inlst)) ;; (tal (cdr inlst)) ;; (res '()) ;; (cur (car tnames)) ;; (rem (cdr tnames))) ;; (let ((tname (vector-ref hed 0)) ;; (ipath (vector-ref hed 1))) ;; (if (equal? tname cur) ;; (if (null? tal) ;; (append res (list hed)) ;; (loop (car tal) ;; (cdr tal) ;; (append res (list hed)) ;; cur ;; rem)) ;; (if (null? tal) ;; ( (define (update-buttons uidat numruns numtests) (let* ((runs (if (> (length *allruns*) numruns) (take-right *allruns* numruns) (pad-list *allruns* numruns))) (lftcol (dboard:uidat-get-lftcol uidat)) (tableheader (dboard:uidat-get-header uidat)) |
︙ | |||
1089 1090 1091 1092 1093 1094 1095 | 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 | - - - - + + + + - + + + - - - + | ;;(iup:textbox #:size "60x15" #:fontsize "10" #:value "%" ;; #:action (lambda (obj unk val) ;; (mark-for-update) ;; (update-search "item-name" val)) )) (iup:vbox (iup:hbox |
︙ |
Modified db.scm from [227dabefc6] to [5e357ac578].
︙ | |||
903 904 905 906 907 908 909 | 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 | - + - | ;; T E S T S ;;====================================================================== ;; states and statuses are lists, turn them into ("PASS","FAIL"...) and use NOT IN ;; i.e. these lists define what to NOT show. ;; states and statuses are required to be lists, empty is ok ;; not-in #t = above behaviour, #f = must match |
︙ | |||
942 943 944 945 946 947 948 | 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 | - - + + + - + + - - | (else ""))) (tests-match-qry (tests:match->sqlqry testpatt)) (qry (conc "SELECT " qryvals " FROM tests WHERE run_id=? AND state != 'DELETED' " states-statuses-qry (if tests-match-qry (conc " AND (" tests-match-qry ") ") "") (case sort-by |
︙ | |||
1011 1012 1013 1014 1015 1016 1017 | 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 | - + - | (if statuses-qry (conc " AND " statuses-qry) "") (if tests-match-qry (conc " AND (" tests-match-qry ") ") "") (case sort-by ((rundir) " ORDER BY length(rundir) DESC;") ((event_time) " ORDER BY event_time ASC;") (else ";")) ))) |
︙ |
Modified mt.scm from [9f3a7e8a6b] to [7e79f8804e].
︙ | |||
62 63 64 65 66 67 68 | 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 | - - + + - + | limit)) (vector header full-list))))) ;;====================================================================== ;; T E S T S ;;====================================================================== |
︙ |
Modified tests.scm from [7cf7299e0f] to [3cf37d1c86].
︙ | |||
155 156 157 158 159 160 161 | 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 | - + | (conc "SELECT id FROM runs WHERE " qrystr " AND id != ?;") (append keyvals (list run-id))) ;; for each run starting with the most recent look to see if there is a matching test ;; if found then return that matching test record (debug:print 4 "selstr: " selstr ", qrystr: " qrystr ", keyvals: " keyvals ", previous run ids found: " prev-run-ids) (if (null? prev-run-ids) #f (let loop ((hed (car prev-run-ids)) (tal (cdr prev-run-ids))) |
︙ | |||
196 197 198 199 200 201 202 | 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 | - + | ;; collect all matching tests for the runs then ;; extract the most recent test and return that. (debug:print 4 "selstr: " selstr ", qrystr: " qrystr ", keyvals: " keyvals ", previous run ids found: " prev-run-ids) (if (null? prev-run-ids) '() ;; no previous runs? return null (let loop ((hed (car prev-run-ids)) (tal (cdr prev-run-ids))) |
︙ |