From 9b427690ecce7fc0dd69d3be5b6921f995462401 Mon Sep 17 00:00:00 2001 From: Laurent Bossavit Date: Wed, 28 Jun 2017 00:38:55 +0200 Subject: [PATCH] :white_check_mark: Tester la logique n-conditions, corriger l'aiguillage, supprimer le warning https://fb.me/react-warning-keys --- __tests__/traverse.test.js | 11 +++++++++++ source/engine/traverse.js | 6 +++--- 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/__tests__/traverse.test.js b/__tests__/traverse.test.js index b137b3c83..c12370477 100644 --- a/__tests__/traverse.test.js +++ b/__tests__/traverse.test.js @@ -61,3 +61,14 @@ describe('analyseSituation on raw rules', function() { */ }); + +describe('analyseSituation with mecanisms', function() { + + it('should handle n-way "or"', function() { + let rawRules = [ + {nom: "startHere", formule: {"une de ces conditions": ["1 > 2", "1 > 0", "0 > 2"]}}], + rules = rawRules.map(enrichRule) + expect(analyseSituation(rules,"startHere")(stateSelector)).to.have.property('nodeValue',true) + }); + +}); diff --git a/source/engine/traverse.js b/source/engine/traverse.js index 4af2ed410..e6a0ff37d 100644 --- a/source/engine/traverse.js +++ b/source/engine/traverse.js @@ -286,7 +286,7 @@ let treat = (situationGate, rules, rule) => rawNode => { value={result.nodeValue} child={ } /> @@ -713,8 +713,8 @@ let treat = (situationGate, rules, rule) => rawNode => { let onNodeType = R.cond([ [R.is(String), treatString], [R.is(Number), treatNumber], - [!R.is(Object), treatOther], - [R.T, treatObject] + [R.is(Object), treatObject], + [R.T, treatOther] ]) return onNodeType(rawNode) }