From f23e26fbbf30a90791c484d8dddb2a5e20660a96 Mon Sep 17 00:00:00 2001 From: Umur Ozkul Date: Tue, 23 Aug 2022 09:20:18 +0200 Subject: [PATCH] tutorial 1 depending --- ...res => ReducerProject_tutorial_0_test.res} | 0 ...cerProject_tutorial_1_multisource_test.res | 67 +++++++++++++++++++ 2 files changed, 67 insertions(+) rename packages/squiggle-lang/__tests__/ReducerProject/{ReducerProject_tutorial_test.res => ReducerProject_tutorial_0_test.res} (100%) create mode 100644 packages/squiggle-lang/__tests__/ReducerProject/ReducerProject_tutorial_1_multisource_test.res diff --git a/packages/squiggle-lang/__tests__/ReducerProject/ReducerProject_tutorial_test.res b/packages/squiggle-lang/__tests__/ReducerProject/ReducerProject_tutorial_0_test.res similarity index 100% rename from packages/squiggle-lang/__tests__/ReducerProject/ReducerProject_tutorial_test.res rename to packages/squiggle-lang/__tests__/ReducerProject/ReducerProject_tutorial_0_test.res diff --git a/packages/squiggle-lang/__tests__/ReducerProject/ReducerProject_tutorial_1_multisource_test.res b/packages/squiggle-lang/__tests__/ReducerProject/ReducerProject_tutorial_1_multisource_test.res new file mode 100644 index 00000000..cc0d45ec --- /dev/null +++ b/packages/squiggle-lang/__tests__/ReducerProject/ReducerProject_tutorial_1_multisource_test.res @@ -0,0 +1,67 @@ +@@warning("-44") +module InternalExpressionValue = ReducerInterface_InternalExpressionValue +module Project = ForTS_ReducerProject +module Bindings = Reducer_Bindings + +open Jest +open Expect +open Expect.Operators + +describe("ReducerProject Tutorial", () => { + describe("Multi source", () => { + /* +Case "Running multiple sources" +*/ + test("Chaining", () => { + let project = Project.createProject() + /* This time let's add 3 sources and chain them together */ + Project.setSource(project, "source1", "x=1") + + Project.setSource(project, "source2", "y=2") + /* To run, source2 depends on source1 */ + Project.setContinues(project, "source2", ["source1"]) + + Project.setSource(project, "source3", "z=3") + /* To run, source3 depends on source2 */ + Project.setContinues(project, "source3", ["source2"]) + + /* Now we can run the project */ + Project.runAll(project) + + /* And let's check the result and bindings of source3 */ + let result3 = Project.getResult(project, "source3") + let bindings3 = Project.getBindings(project, "source3") + + ( + result3->InternalExpressionValue.toStringOptionResult, + bindings3->InternalExpressionValue.IEvBindings->InternalExpressionValue.toString, + )->expect == ("Ok(())", "@{x: 1,y: 2,z: 3}") + }) + + test("Depending", () => { + /* Instead of chaining the sources, we could have a dependency tree */ + /* The point here is that any source can depend on multiple sources */ + let project = Project.createProject() + + /* This time source1 and source2 are not depending on anything */ + Project.setSource(project, "source1", "x=1") + Project.setSource(project, "source2", "y=2") + + Project.setSource(project, "source3", "z=3") + /* To run, source3 depends on source1 and source3 together */ + Project.setContinues(project, "source3", ["source1", "source2"]) + + /* Now we can run the project */ + Project.runAll(project) + + /* And let's check the result and bindings of source3 */ + let result3 = Project.getResult(project, "source3") + let bindings3 = Project.getBindings(project, "source3") + + ( + result3->InternalExpressionValue.toStringOptionResult, + bindings3->InternalExpressionValue.IEvBindings->InternalExpressionValue.toString, + )->expect == ("Ok(())", "@{x: 1,y: 2,z: 3}") + }) + }) +})