From fb16530b8ff68dfecd40f816ada337d35960bc5f Mon Sep 17 00:00:00 2001 From: Robin van Boven <497556+Beanow@users.noreply.github.com> Date: Fri, 3 Jan 2020 14:50:20 +0100 Subject: [PATCH] Update projectFromJSON & upgrade function signatures (#1518) This creates better flow type coverage for the upgrading from older Project types feature. Note projectFromJSON's function signature changes like this: - (Compatible) => Project + (Compatible) => Project And that makes sense, because we use this function to validate an object we parsed from JSON at runtime. It could actually be anything. Added benefit is that is makes writing unit tests possible. Because now will flow not throw a type error when we provide something other than Compatible as input, to test upgrading or validation functionality. Note that the underlying utility fromCompat already uses Compatible for the same object. --- src/core/project.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/core/project.js b/src/core/project.js index 26a30ea..cb6570d 100644 --- a/src/core/project.js +++ b/src/core/project.js @@ -42,7 +42,7 @@ export function projectToJSON(p: Project): ProjectJSON { return toCompat(COMPAT_INFO, p); } -export function projectFromJSON(j: ProjectJSON): Project { +export function projectFromJSON(j: Compatible): Project { return fromCompat(COMPAT_INFO, j, upgrades); } @@ -54,7 +54,7 @@ export function encodeProjectId(id: ProjectId): string { return base64url.encode(id); } -const upgradeFrom030 = (p) => ({ +const upgradeFrom030 = (p: Project_v030 | Project_v031): Project_v040 => ({ ...p, discourseServer: p.discourseServer != null ? {serverUrl: p.discourseServer.serverUrl} : null,