From 94b8f2d096c39dcdb091170dca60f2565e99a7fa Mon Sep 17 00:00:00 2001 From: Katinka Tauber Date: Tue, 12 Sep 2023 14:20:16 +0200 Subject: [PATCH] Process all examples as integration tests. See #121 --- .../metafacture_playground/process_test.clj | 99 ++++++++++--------- 1 file changed, 54 insertions(+), 45 deletions(-) diff --git a/test/clj/metafacture_playground/process_test.clj b/test/clj/metafacture_playground/process_test.clj index fc8ba3e..a20c20b 100644 --- a/test/clj/metafacture_playground/process_test.clj +++ b/test/clj/metafacture_playground/process_test.clj @@ -1,49 +1,58 @@ (ns metafacture-playground.process-test - (:require [clojure.test :refer :all] - [metafacture-playground.process :refer [process]])) + (:require [clojure.test :refer [deftest testing is]] + [metafacture-playground.process :refer [process]] + [clojure.java.io :as io] + [lambdaisland.uri :refer [uri query-string->map]])) -; TODO: we should extract the samples here and in db.cljs to files -(def sample-data {:data "1{a: Faust, b {n: Goethe, v: JW}, c: Weimar}\n2{a: Räuber, b {n: Schiller, v: F}, c: Weimar}" - :flux-with-fix "inputFile|\nopen-file\n|as-lines\n|decode-formeta\n|fix(transformationFile)\n|encode-xml(rootTag=\"collection\")\n|print\n;" - :flux-with-morph "inputFile|\nopen-file\n|as-lines\n|decode-formeta\n|morph(transformationFile)\n|encode-xml(rootTag=\"collection\")\n|print\n;" - :fix "move_field(_id, id)\nmove_field(a, title)\npaste(author, b.v, b.n, '~aus', c)\nretain(id, title, author)" - :morph (str "\n" - "\n" - "\t\n" - "\t\t\n" - "\t\t\n" - "\t\t\n" - "\t\t\t\n" - "\t\t\t\n" - "\t\t\t\n" - "\t\t\n" - "\t\n" - "\n")}) +(deftest processing-correctly-test + (let [test-data {:data "1{a: Faust, b {n: Goethe, v: JW}, c: Weimar}\n2{a: Räuber, b {n: Schiller, v: F}, c: Weimar}" + :flux-with-fix "inputFile|\nopen-file\n|as-lines\n|decode-formeta\n|fix(transformationFile)\n|encode-xml(rootTag=\"collection\")\n|print\n;" + :flux-with-morph "inputFile|\nopen-file\n|as-lines\n|decode-formeta\n|morph(transformationFile)\n|encode-xml(rootTag=\"collection\")\n|print\n;" + :fix "move_field(_id, id)\nmove_field(a, title)\npaste(author, b.v, b.n, '~aus', c)\nretain(id, title, author)" + :morph (str "\n" + "\n" + "\t\n" + "\t\t\n" + "\t\t\n" + "\t\t\n" + "\t\t\t\n" + "\t\t\t\n" + "\t\t\t\n" + "\t\t\n" + "\t\n" + "\n") + :result (str "" + "\n" + "\n" + "\n " + "\n 1" + "\n Faust" + "\n JW Goethe aus Weimar" + "\n " + "\n" + "\n " + "\n 2" + "\n Räuber" + "\n F Schiller aus Weimar" + "\n " + "\n" + "\n\n")}] + (testing "Process sample data (with fix) with correct result." + (let [result (process (:flux-with-fix test-data) (:data test-data) (:fix test-data))] + (is (= result (:result test-data))))) -(def test-data (merge sample-data - {:result (str "" - "\n" - "\n" - "\n " - "\n 1" - "\n Faust" - "\n JW Goethe aus Weimar" - "\n " - "\n" - "\n " - "\n 2" - "\n Räuber" - "\n F Schiller aus Weimar" - "\n " - "\n" - "\n\n")})) + (testing "Process sample data (with morph) with correct result." + (let [result (process (:flux-with-morph test-data) (:data test-data) (:morph test-data))] + (is (= result (:result test-data))))))) -(deftest processing-test - (testing "Process sample data (with fix) correctly." - (let [result (process (:flux-with-fix test-data) (:data test-data) (:fix test-data))] - (is (= result (:result test-data))))) - - (testing "Process sample data (with morph) correctly." - (let [result (process (:flux-with-morph test-data) (:data test-data) (:morph test-data))] - (is (= result (:result test-data)))))) +(deftest process-examples-test + (testing "Process all examples in resources/examples without exceptions." + (let [examples (->> (io/resource "examples") + io/file + .listFiles + (keep #(when (.isFile %) + (slurp %))) + (map #(-> % uri :query query-string->map)))] + (doseq [example examples] + (is (process (:flux example) (:data example) (:transformation example)))))))