From ac5192acd261520488dcdea312be48b27a100ee7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Wiktor=20Tkaczy=C5=84ski?= Date: Fri, 8 Nov 2024 11:30:02 +0100 Subject: [PATCH] fix: initialize arrays to string value Arrays are stored as strings in the database so we have to initialize them as such as well. --- src/codegen.ts | 2 +- test/unit/__snapshots__/codegen.test.ts.snap | 8 ++++---- test/unit/codegen.test.ts | 6 +++--- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/src/codegen.ts b/src/codegen.ts index c24a3c1..01be436 100644 --- a/src/codegen.ts +++ b/src/codegen.ts @@ -74,7 +74,7 @@ export const getTypeInfo = ( const nonNullNestedType = type.ofType instanceof GraphQLNonNull ? type.ofType.ofType : type.ofType; - return { type: `${getTypeInfo(nonNullNestedType, decimalTypes).type}[]`, initialValue: [] }; + return { type: `${getTypeInfo(nonNullNestedType, decimalTypes).type}[]`, initialValue: '[]' }; } throw new Error('Unknown type'); diff --git a/test/unit/__snapshots__/codegen.test.ts.snap b/test/unit/__snapshots__/codegen.test.ts.snap index 2111686..5498b22 100644 --- a/test/unit/__snapshots__/codegen.test.ts.snap +++ b/test/unit/__snapshots__/codegen.test.ts.snap @@ -16,8 +16,8 @@ export class Space extends Model { this.initialSet('voting_delay', 0); this.initialSet('proposal_threshold', 0); this.initialSet('quorum', 0); - this.initialSet('strategies', []); - this.initialSet('strategies_nonnull', []); + this.initialSet('strategies', "[]"); + this.initialSet('strategies_nonnull', "[]"); } static async loadEntity(id) { @@ -217,8 +217,8 @@ export class Space extends Model { this.initialSet('voting_delay', 0); this.initialSet('proposal_threshold', 0); this.initialSet('quorum', 0); - this.initialSet('strategies', []); - this.initialSet('strategies_nonnull', []); + this.initialSet('strategies', "[]"); + this.initialSet('strategies_nonnull', "[]"); } static async loadEntity(id: string): Promise { diff --git a/test/unit/codegen.test.ts b/test/unit/codegen.test.ts index e705dcb..9daed5e 100644 --- a/test/unit/codegen.test.ts +++ b/test/unit/codegen.test.ts @@ -100,9 +100,9 @@ describe('getInitialValue', () => { expect(getInitialValue(proposalFields['active'].type)).toBe(false); }); - it('should return empty array for List types', () => { - expect(getInitialValue(spaceFields['strategies'].type)).toEqual([]); - expect(getInitialValue(spaceFields['strategies_nonnull'].type)).toEqual([]); + it('should return stringified empty array for List types', () => { + expect(getInitialValue(spaceFields['strategies'].type)).toEqual('[]'); + expect(getInitialValue(spaceFields['strategies_nonnull'].type)).toEqual('[]'); }); it('should return empty string for object types', () => {