2019-05-24 07:43:49 +00:00
|
|
|
; Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
; or more contributor license agreements. See the NOTICE file
|
|
|
|
; distributed with this work for additional information
|
|
|
|
; regarding copyright ownership. The ASF licenses this file
|
|
|
|
; to you under the Apache License, Version 2.0 (the
|
|
|
|
; "License"); you may not use this file except in compliance
|
|
|
|
; with the License. You may obtain a copy of the License at
|
|
|
|
;
|
|
|
|
; http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
;
|
|
|
|
; Unless required by applicable law or agreed to in writing, software
|
|
|
|
; distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
; See the License for the specific language governing permissions and
|
|
|
|
; limitations under the License.
|
|
|
|
(ns data-test.file-loader
|
|
|
|
(:require
|
|
|
|
[clojure.java.io :as io]
|
|
|
|
[clojure.string :as str]
|
|
|
|
[schema.core :as s]
|
|
|
|
[aero.core :as aero]))
|
|
|
|
|
|
|
|
;TODO: replace schema with spec
|
|
|
|
(def TestDataSpec
|
|
|
|
{:input s/Any
|
|
|
|
:expectation s/Any})
|
|
|
|
|
2019-05-24 12:54:18 +00:00
|
|
|
(s/defn read-test-data-spec :- TestDataSpec
|
2019-05-24 07:43:49 +00:00
|
|
|
[resource-url :- s/Str]
|
|
|
|
(aero/read-config resource-url))
|
|
|
|
|
2019-05-24 12:54:18 +00:00
|
|
|
(s/defn data-test-spec-file-prefix :- s/Str
|
2019-05-24 07:43:49 +00:00
|
|
|
[name-key :- s/Keyword]
|
|
|
|
(str/replace
|
|
|
|
(str/replace (str (namespace name-key) "/" (name name-key))
|
|
|
|
#"-" "_")
|
|
|
|
#"\." "/"))
|
|
|
|
|
2019-05-24 13:17:25 +00:00
|
|
|
(s/defn data-test-spec-file-names :- [s/Str]
|
|
|
|
[name-key :- s/Keyword]
|
|
|
|
(let [prefix (data-test-spec-file-prefix name-key)]
|
|
|
|
(cons (str prefix ".edn")
|
|
|
|
(map #(str prefix "." % ".edn")
|
|
|
|
(range 10)))))
|
2019-05-24 12:54:18 +00:00
|
|
|
|
2019-05-24 07:43:49 +00:00
|
|
|
(s/defn load-test-data
|
|
|
|
[file-prefix :- s/Str]
|
|
|
|
(let [file-path (str file-prefix ".edn")]
|
2019-05-24 11:17:59 +00:00
|
|
|
(try
|
2019-05-24 12:54:18 +00:00
|
|
|
(read-test-data-spec (io/resource file-path))
|
2019-05-24 11:17:59 +00:00
|
|
|
(catch IllegalArgumentException e
|
2019-05-24 11:31:12 +00:00
|
|
|
(throw (ex-info (str "Could not find test spec on " file-path)
|
2019-05-24 12:12:51 +00:00
|
|
|
{:message "Could not find test spec"
|
|
|
|
:file-path file-prefix} e))))))
|