From 116f85f7ae63c22618faefbdfcdb257242ad227e Mon Sep 17 00:00:00 2001 From: Nicholas Vinson Date: Fri, 4 Oct 2024 19:03:22 -0400 Subject: [PATCH 1/2] Correct getAllContext() behavior Correct getAllContext() to return the root node's context in addition to specified defaults. Closes: #2239 Signed-off-by: Nicholas Vinson --- src/construct.ts | 10 ++-------- test/construct.test.ts | 17 +++++++++++++++++ 2 files changed, 19 insertions(+), 8 deletions(-) diff --git a/src/construct.ts b/src/construct.ts index 1f946bfe..0c70aee2 100644 --- a/src/construct.ts +++ b/src/construct.ts @@ -245,14 +245,8 @@ export class Node { * @returns The context object or an empty object if there is discovered context */ public getAllContext(defaults?: object): any { - if (typeof defaults === 'undefined') { - defaults = {}; - } - - if (this.scope === undefined) { return defaults; } - - const value = { ...this._context, ...defaults }; - return this.scope && this.scope.node.getAllContext(value); + return this.scopes.reverse() + .reduce((a, s) => ({ ...(s.node._context), ...a }), { ...defaults }); } /** diff --git a/test/construct.test.ts b/test/construct.test.ts index ebc92941..e1c1ed6c 100644 --- a/test/construct.test.ts +++ b/test/construct.test.ts @@ -150,6 +150,23 @@ test('construct.getContext(key) throws if context is not defined', () => { }).toThrowError(`No context value present for ${key} key`); }); +test('construct.getAllContext can be used to read the full context of a root node', () => { + // GIVEN + const context = { + ctx1: 12, + ctx2: 'hello', + }; + + // WHEN + const t = new Root(); + for (const [k, v] of Object.entries(context)) { + t.node.setContext(k, v); + } + + // THEN + expect(t.node.getAllContext()).toStrictEqual(context); +}); + test('construct.getAllContext can be used to read the full context of a node', () => { // GIVEN const context = { From dba46c89f76bbda212f2c78613465a193b23261e Mon Sep 17 00:00:00 2001 From: Momo Kornher Date: Thu, 10 Oct 2024 18:07:11 +0100 Subject: [PATCH 2/2] fix formatting --- src/construct.ts | 2 +- test/construct.test.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/construct.ts b/src/construct.ts index 0c70aee2..ba2988b8 100644 --- a/src/construct.ts +++ b/src/construct.ts @@ -246,7 +246,7 @@ export class Node { */ public getAllContext(defaults?: object): any { return this.scopes.reverse() - .reduce((a, s) => ({ ...(s.node._context), ...a }), { ...defaults }); + .reduce((a, s) => ({ ...(s.node._context), ...a }), { ...defaults }); } /** diff --git a/test/construct.test.ts b/test/construct.test.ts index e1c1ed6c..5da39baa 100644 --- a/test/construct.test.ts +++ b/test/construct.test.ts @@ -160,7 +160,7 @@ test('construct.getAllContext can be used to read the full context of a root nod // WHEN const t = new Root(); for (const [k, v] of Object.entries(context)) { - t.node.setContext(k, v); + t.node.setContext(k, v); } // THEN