aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/test/aedifex/command/pom.lux
blob: 80676974bb9db552fbddd1aa597b935c850a4760 (plain)
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
(.module:
  [library
   [lux "*"
    ["_" test {"+" [Test]}]
    [abstract
     [monad {"+" [do]}]]
    [control
     ["[0]" try ("[1]\[0]" functor)]
     [concurrency
      ["[0]" async]]]
    [data
     ["[0]" binary ("[1]\[0]" equivalence)]
     ["[0]" text ("[1]\[0]" equivalence)
      [encoding
       ["[0]" utf8]]]
     [format
      ["[0]" xml]]]
    [math
     ["[0]" random]]
    [world
     ["[0]" file]]]]
  [//
   ["@[0]" version]
   [//
    ["@[0]" profile]]]
  [\\program
   ["[0]" /
    ["//[1]" /// "_"
     ["[1]" profile]
     ["[1][0]" action]
     ["[1][0]" pom]]]])

(def: .public test
  Test
  (<| (_.covering /._)
      (do random.monad
        [sample @profile.random
         .let [fs (file.mock (\ file.default separator))]]
        (in (do [! async.monad]
              [.let [console (@version.echo "")]
               outcome (/.do! console fs sample)]
              (case outcome
                (#try.Success _)
                (do !
                  [verdict (do ///action.monad
                             [expected (|> (///pom.write sample)
                                           (try\each (|>> (\ xml.codec encoded)
                                                          (\ utf8.codec encoded)))
                                           (\ ! in))
                              actual (\ fs read ///pom.file)

                              logging! (\ ///action.monad each
                                          (text\= /.success)
                                          (\ console read_line []))

                              .let [expected_content!
                                    (binary\= expected actual)]]
                             (in (and logging!
                                      expected_content!)))]
                  (_.cover' [/.do! /.success]
                            (try.else false verdict)))
                
                (#try.Failure error)
                (_.cover' [/.do!]
                          (case (value@ #///.identity sample)
                            (#.Some _)
                            false

                            #.None
                            true))))))))