|
| 1 | +let JSON = https://prelude.dhall-lang.org/JSON/package.dhall |
| 2 | + |
| 3 | +let List/map = https://prelude.dhall-lang.org/List/map |
| 4 | + |
| 5 | +let Optional/map = https://prelude.dhall-lang.org/Optional/map |
| 6 | + |
| 7 | +let Map = https://prelude.dhall-lang.org/Map/Type |
| 8 | + |
| 9 | +let HttpMethod |
| 10 | + : Type |
| 11 | + = < GET | POST | PUT | PATCH | DELETE > |
| 12 | + |
| 13 | +let PartialMatcher = |
| 14 | + < KeyMatch : Text |
| 15 | + | ValueMatch : JSON.Type |
| 16 | + | KeyValueMatch : { key : Text, value : JSON.Type } |
| 17 | + > |
| 18 | + |
| 19 | +let ExpectData = |
| 20 | + < Exactly : JSON.Type |
| 21 | + | Contains : List PartialMatcher |
| 22 | + | NotContains : List PartialMatcher |
| 23 | + | MixedContains : |
| 24 | + { contains : List PartialMatcher, notContains : List PartialMatcher } |
| 25 | + > |
| 26 | + |
| 27 | +let KeyValMatchHydrated = |
| 28 | + { keyMatch : Optional PartialMatcher |
| 29 | + , valueMatch : Optional PartialMatcher |
| 30 | + , keyValueMatch : Optional PartialMatcher |
| 31 | + } |
| 32 | + |
| 33 | +let ExpectHeaders = |
| 34 | + < HeaderString : Text |
| 35 | + | HeaderKeyVal : { key : Optional Text, value : Optional Text } |
| 36 | + > |
| 37 | + |
| 38 | +let hydrateContains = |
| 39 | + λ(containsMatcher : PartialMatcher) → |
| 40 | + merge |
| 41 | + { KeyMatch = |
| 42 | + λ(k : Text) → |
| 43 | + { keyMatch = Some (PartialMatcher.KeyMatch k) |
| 44 | + , valueMatch = None PartialMatcher |
| 45 | + , keyValueMatch = None PartialMatcher |
| 46 | + } |
| 47 | + , ValueMatch = |
| 48 | + λ(v : JSON.Type) → |
| 49 | + { keyMatch = None PartialMatcher |
| 50 | + , valueMatch = Some (PartialMatcher.ValueMatch v) |
| 51 | + , keyValueMatch = None PartialMatcher |
| 52 | + } |
| 53 | + , KeyValueMatch = |
| 54 | + λ(args : { key : Text, value : JSON.Type }) → |
| 55 | + { keyMatch = None PartialMatcher |
| 56 | + , valueMatch = None PartialMatcher |
| 57 | + , keyValueMatch = Some |
| 58 | + ( PartialMatcher.KeyValueMatch |
| 59 | + { key = args.key, value = args.value } |
| 60 | + ) |
| 61 | + } |
| 62 | + } |
| 63 | + containsMatcher |
| 64 | + |
| 65 | +let ExpectResponseHydrated = |
| 66 | + { exactly : Optional ExpectData |
| 67 | + , contains : Optional (List KeyValMatchHydrated) |
| 68 | + , notContains : Optional (List KeyValMatchHydrated) |
| 69 | + } |
| 70 | + |
| 71 | +let hydrateExpectData = |
| 72 | + λ(matcher : ExpectData) → |
| 73 | + merge |
| 74 | + { Exactly = |
| 75 | + λ(j : JSON.Type) → |
| 76 | + { exactly = Some (ExpectData.Exactly j) |
| 77 | + , contains = None (List KeyValMatchHydrated) |
| 78 | + , notContains = None (List KeyValMatchHydrated) |
| 79 | + } |
| 80 | + , Contains = |
| 81 | + λ(ms : List PartialMatcher) → |
| 82 | + { exactly = None ExpectData |
| 83 | + , contains = Some |
| 84 | + ( List/map |
| 85 | + PartialMatcher |
| 86 | + KeyValMatchHydrated |
| 87 | + hydrateContains |
| 88 | + ms |
| 89 | + ) |
| 90 | + , notContains = None (List KeyValMatchHydrated) |
| 91 | + } |
| 92 | + , NotContains = |
| 93 | + λ(ms : List PartialMatcher) → |
| 94 | + { exactly = None ExpectData |
| 95 | + , contains = None (List KeyValMatchHydrated) |
| 96 | + , notContains = Some |
| 97 | + ( List/map |
| 98 | + PartialMatcher |
| 99 | + KeyValMatchHydrated |
| 100 | + hydrateContains |
| 101 | + ms |
| 102 | + ) |
| 103 | + } |
| 104 | + , MixedContains = |
| 105 | + λ ( args |
| 106 | + : { contains : List PartialMatcher |
| 107 | + , notContains : List PartialMatcher |
| 108 | + } |
| 109 | + ) → |
| 110 | + { exactly = None ExpectData |
| 111 | + , contains = Some |
| 112 | + ( List/map |
| 113 | + PartialMatcher |
| 114 | + KeyValMatchHydrated |
| 115 | + hydrateContains |
| 116 | + args.contains |
| 117 | + ) |
| 118 | + , notContains = Some |
| 119 | + ( List/map |
| 120 | + PartialMatcher |
| 121 | + KeyValMatchHydrated |
| 122 | + hydrateContains |
| 123 | + args.notContains |
| 124 | + ) |
| 125 | + } |
| 126 | + } |
| 127 | + matcher |
| 128 | + |
| 129 | +let BodyType = < json | urlencoded > |
| 130 | + |
| 131 | +let RequestData = < JSON : JSON.Type | UrlEncoded : Map Text Text > |
| 132 | + |
| 133 | +let RequestDataHydrated = { bodyType : BodyType, content : RequestData } |
| 134 | + |
| 135 | +let hydrateRquestData = |
| 136 | + λ(reqData : RequestData) → |
| 137 | + merge |
| 138 | + { JSON = |
| 139 | + λ(json : JSON.Type) → |
| 140 | + { bodyType = BodyType.json, content = RequestData.JSON json } |
| 141 | + , UrlEncoded = |
| 142 | + λ(encoded : Map Text Text) → |
| 143 | + { bodyType = BodyType.urlencoded |
| 144 | + , content = RequestData.UrlEncoded encoded |
| 145 | + } |
| 146 | + } |
| 147 | + reqData |
| 148 | + |
| 149 | +let makeQueryParams = |
| 150 | + λ(params : Map Text Text) → |
| 151 | + JSON.object |
| 152 | + ( List/map |
| 153 | + { mapKey : Text, mapValue : Text } |
| 154 | + { mapKey : Text, mapValue : JSON.Type } |
| 155 | + ( λ(args : { mapKey : Text, mapValue : Text }) → |
| 156 | + { mapKey = args.mapKey, mapValue = JSON.string args.mapValue } |
| 157 | + ) |
| 158 | + params |
| 159 | + ) |
| 160 | + |
| 161 | +let QueryParams = List { mapKey : Text, mapValue : JSON.Type } |
| 162 | + |
| 163 | +let Case = |
| 164 | + { Type = |
| 165 | + { name : Text |
| 166 | + , url : Text |
| 167 | + , requestMethod : HttpMethod |
| 168 | + , queryParameters : Map Text Text |
| 169 | + , expectData : Optional ExpectData |
| 170 | + , expectStatus : Natural |
| 171 | + , headers : Optional Text |
| 172 | + , expectHeaders : Optional (List ExpectHeaders) |
| 173 | + , allowedRedirects : Natural |
| 174 | + , requestData : Optional RequestData |
| 175 | + } |
| 176 | + , default = |
| 177 | + { expectData = None ExpectData |
| 178 | + , headers = None Text |
| 179 | + , expectHeaders = None (List ExpectHeaders) |
| 180 | + , allowedRedirects = 10 |
| 181 | + , queryParameters = [] : Map Text Text |
| 182 | + , requestData = None RequestData |
| 183 | + } |
| 184 | + } |
| 185 | + |
| 186 | +let HydratedCase = |
| 187 | + { Type = |
| 188 | + { name : Text |
| 189 | + , url : Text |
| 190 | + , requestMethod : HttpMethod |
| 191 | + , queryParameters : JSON.Type |
| 192 | + , expectData : Optional ExpectResponseHydrated |
| 193 | + , expectStatus : Natural |
| 194 | + , headers : Optional Text |
| 195 | + , expectHeaders : Optional (List ExpectHeaders) |
| 196 | + , allowedRedirects : Natural |
| 197 | + , requestData : Optional RequestDataHydrated |
| 198 | + } |
| 199 | + , default = |
| 200 | + { expectData = None ExpectResponseHydrated |
| 201 | + , headers = None Text |
| 202 | + , expectHeaders = None (List ExpectHeaders) |
| 203 | + , allowedRedirects = 10 |
| 204 | + , queryParameters = JSON.null |
| 205 | + , requestData = None RequestDataHydrated |
| 206 | + } |
| 207 | + } |
| 208 | + |
| 209 | +let hydrateCase = |
| 210 | + λ(c : Case.Type) → |
| 211 | + c |
| 212 | + ⫽ { queryParameters = makeQueryParams c.queryParameters |
| 213 | + , expectData = |
| 214 | + Optional/map |
| 215 | + ExpectData |
| 216 | + ExpectResponseHydrated |
| 217 | + hydrateExpectData |
| 218 | + c.expectData |
| 219 | + , requestData = |
| 220 | + Optional/map |
| 221 | + RequestData |
| 222 | + RequestDataHydrated |
| 223 | + hydrateRquestData |
| 224 | + c.requestData |
| 225 | + } |
| 226 | + |
| 227 | +let hydrateCases = |
| 228 | + λ(cases : List Case.Type) → |
| 229 | + List/map Case.Type HydratedCase.Type hydrateCase cases |
| 230 | + |
| 231 | +in { Case |
| 232 | + , HydratedCase |
| 233 | + , hydrateCase |
| 234 | + , hydrateCases |
| 235 | + , HttpMethod |
| 236 | + , ExpectData |
| 237 | + , PartialMatcher |
| 238 | + , ExpectHeaders |
| 239 | + , RequestData |
| 240 | + } |
0 commit comments