15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
;;
;; You should have received a copy of the GNU General Public License
;; along with Megatest. If not, see <http://www.gnu.org/licenses/>.
;;======================================================================
(declare (unit genexample))
(use posix regex)
(define genexample:example-logpro
#<<EOF
;; You should have at least one expect:required. This ensures that your process ran
;; comment out the line below and replace "put pattern here" with a pattern that will
;; always be seen in your log file if the step runs successfully.
;;
|
|
>
>
|
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
;;
;; You should have received a copy of the GNU General Public License
;; along with Megatest. If not, see <http://www.gnu.org/licenses/>.
;;======================================================================
(declare (unit genexample))
(use posix regex matchable)
(include "db_records.scm")
(define genexample:example-logpro
#<<EOF
;; You should have at least one expect:required. This ensures that your process ran
;; comment out the line below and replace "put pattern here" with a pattern that will
;; always be seen in your log file if the step runs successfully.
;;
|
336
337
338
339
340
341
342
|
(if (string-match ".*\\.sh$" script)
(begin
(with-output-to-file (conc testdir "/" script)
(lambda ()
(print genexample:example-script)))
(system (conc "chmod ug+r,a+x " (conc testdir "/" script)))))))
steps))))))
|
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
|
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
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
|
(if (string-match ".*\\.sh$" script)
(begin
(with-output-to-file (conc testdir "/" script)
(lambda ()
(print genexample:example-script)))
(system (conc "chmod ug+r,a+x " (conc testdir "/" script)))))))
steps))))))
;; easier to work backwards than change the upstream code
;;
(define (hrs-min-sec->seconds str)
(let* ((parts (string-split str))
(res 0))
(for-each
(lambda (part)
(set! res
(+ res
(match (string-match "(\\d+)([a-z])" part)
((_ val units)(* (string->number val)(case (string->symbol units)
((s) 1)
((m) 60)
((h) 3600))))
(else 0)))))
parts)
res))
;; generate a skeleton Megatest area from a current area with runs
;;
;; specify target, runname etc to use specific runs for the template
;;
(define (genexample:extract-skeleton-area dest-path)
(let* ((target (args:get-arg "-target"))
(runname (args:get-arg "-runname")))
(if (not (and target runname))
(debug:print 0 *default-log-port* "WARNING: For best results please specifiy -target and -runname for a good run to use as a template."))
(if (not (and (file-exists? "megatest.config")
(file-exists? "megatest.db")))
(begin
(debug:print 0 *default-log-port* "ERROR: this command must be run at the top level of a megatest area where runs have been completed")
(exit)))
;; first create the dest path and needed subdirectories
(if (not (file-exists? dest-path))
(begin
(create-directory dest-path)
(create-directory (conc dest-path "/tests")))
(if (file-exists? (conc dest-path "/megatest.config"))
(begin
(debug:print 0 *default-log-port* "ERROR: destination path already has megatest.config, stopping now.")
(exit))))
;; dump the config files from this area to the dest area
(system (conc "megatest -show-config > " dest-path "/megatest.config"))
(system (conc "megatest -show-runconfig > " dest-path "/runconfigs.config"))
;; create stepsinfo and items refdbs, some stuff has to be done due to refdb not initing area
;;
;; sheet row col value
;; stepsinfo testname itempath stepname steptime
;; miscinfo "itemsinfo" testname itempath "x"
;;
(for-each
(lambda (rdbname)
(if (not (file-exists? (conc dest-path "/" rdbname)))
(begin
(create-directory (conc dest-path "/" rdbname "/sxml") #t)
(with-output-to-file (conc dest-path "/" rdbname "/sheet-names.cfg")
(lambda ()(print))))))
'("stepsinfo" "miscinfo"))
(let* ((runs (rmt:simple-get-runs (or runname "%") #f #f (or target "%")))
(tests (make-hash-table)) ;; just tests
(fullt (make-hash-table)) ;; all test/items
(testreg (make-hash-table)) ;; for the testconfigs
(stepsrdb (conc dest-path "/stepsinfo"))
(miscrdb (conc dest-path "/miscinfo")))
(if (> (length runs) 1)
(debug:print-info 0 *default-log-port* "More than one run matches, first found data will be used."))
;; get all testnames
(for-each
(lambda (run-id)
(let* ((tests-data (rmt:get-tests-for-run run-id "%" '() '() #f #f #f #f #f #f #f #f)))
(for-each
(lambda (testdat)
(let* ((test-id (db:test-get-id testdat))
(testname (db:test-get-testname testdat))
(item-path (db:test-get-item-path testdat))
(tlevel (db:test-get-is-toplevel testdat))
(tfullname (db:test-get-fullname testdat))
;; now get steps info
(test-steps (tests:get-compressed-steps run-id test-id))
(testconfig (tests:get-testconfig testname item-path testreg #f)))
(if (not (hash-table-exists? fullt tfullname))
;; do the work for this test if not previously done
(let* ((new-test-dir (conc dest-path "/tests/" testname))
(tconfigf (conc new-test-dir "/testconfig")))
(print "Analyzing and extracting info for " tfullname)
(print " toplevel: " (if tlevel "yes" "no"))
(hash-table-set! fullt tfullname #t) ;; track that this one has been seen
(if (not (directory-exists? new-test-dir))
(create-directory new-test-dir #t))
;; create the testconfig IIF we are a toplevel or an item AND the testconfig has not been previously created
(if (and (or (not tlevel)
(not (equal? item-path "")))
(not (file-exists? tconfigf)))
(with-output-to-file tconfigf
(lambda ()
;; first the ezsteps
(print "[ezsteps]")
(for-each
(lambda (teststep)
(let* ((step-name (vector-ref teststep 0)))
(print step-name " sleep [refdb lookup #{getenv MT_RUN_AREA_HOME}/" stepsrdb " " testname " $MT_ITEM_PATH " step-name "]")))
test-steps)
;; now the requirements section
(print "\n[requirements]")
(for-each
(lambda (entry)
(print (car entry) " " (cadr entry))) ;; it is not an alist
(configf:get-section testconfig "requirements"))
(print "[items]")
(print "THE_ITEM [refdb getrow #{getenv MT_RUN_AREA_HOME}/miscinfo itemsinfo #{getenv MT_TESTNAME}| awk '{print $1}'")
)))
;; fill the stepsrdb
(for-each
(lambda (teststep)
(let* ((step-name (vector-ref teststep 0))
(step-duration (hrs-min-sec->seconds (vector-ref teststep 4))))
(system (conc "refdb set " stepsrdb " " testname " '" (if (equal? item-path "")
"no-item-path"
item-path)
"' " step-name " " step-duration))))
test-steps)
;; miscinfo "itemsinfo" testname itempath "x"
(if (not (equal? item-path ""))
(system (conc "refdb set " miscrdb " itemsinfo " testname " " item-path " x")))
))))
tests-data)))
(map (lambda (runrec)(simple-run-id runrec)) runs)))
))
|