From a046f8728aa96b4113ca1c3e15702c3b7792c648 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Florian=20G=C3=B6=C3=9Fler?= Date: Mon, 13 Jan 2025 07:54:22 +0100 Subject: [PATCH] fix(datamodel-renderer): sort generator fields deterministically (#5114) Fixes https://github.com/prisma/prisma/issues/17899 --- schema-engine/datamodel-renderer/Cargo.toml | 1 + .../src/configuration/generator.rs | 31 +++++++++++++++++-- 2 files changed, 29 insertions(+), 3 deletions(-) diff --git a/schema-engine/datamodel-renderer/Cargo.toml b/schema-engine/datamodel-renderer/Cargo.toml index b74352589e12..53355a174ff0 100644 --- a/schema-engine/datamodel-renderer/Cargo.toml +++ b/schema-engine/datamodel-renderer/Cargo.toml @@ -7,6 +7,7 @@ edition = "2021" once_cell = "1.15.0" psl.workspace = true regex.workspace = true +itertools.workspace = true base64 = "0.13.1" [dev-dependencies] diff --git a/schema-engine/datamodel-renderer/src/configuration/generator.rs b/schema-engine/datamodel-renderer/src/configuration/generator.rs index df95ad06ee59..62bd9e53c5a0 100644 --- a/schema-engine/datamodel-renderer/src/configuration/generator.rs +++ b/schema-engine/datamodel-renderer/src/configuration/generator.rs @@ -1,4 +1,5 @@ use crate::value::{Array, Documentation, Env, Text, Value}; +use itertools::Itertools; use psl::PreviewFeature; use std::{borrow::Cow, fmt}; @@ -143,7 +144,7 @@ impl fmt::Display for Generator<'_> { writeln!(f, "binaryTargets = {}", self.binary_targets)?; } - for (k, v) in self.config.iter() { + for (k, v) in self.config.iter().sorted_by_key(|(k, _)| k) { writeln!(f, "{k} = {v}")?; } @@ -198,14 +199,38 @@ mod tests { output = "/dev/null" previewFeatures = ["multiSchema", "postgresqlExtensions"] binaryTargets = [env("BINARY TARGET")] + afterGenerate = ["lambda", [], ["print", ["quote", "done!"]]] + customFeatures = ["enums", "models"] customValue = "meow" otherValue = "purr" - customFeatures = ["enums", "models"] - afterGenerate = ["lambda", [], ["print", ["quote", "done!"]]] } "#]]; let rendered = psl::reformat(&format!("{generator}"), 2).unwrap(); expected.assert_eq(&rendered) } + + #[test] + fn creates_consistent_ordering() { + let mut generator1 = Generator::new("client", Env::value("prisma-client-js")); + generator1.push_config_value("first", "A"); + generator1.push_config_value("second", "B"); + let rendered1 = psl::reformat(&format!("{generator1}"), 2).unwrap(); + + let mut generator2 = Generator::new("client", Env::value("prisma-client-js")); + generator2.push_config_value("second", "B"); + generator2.push_config_value("first", "A"); + let rendered2 = psl::reformat(&format!("{generator2}"), 2).unwrap(); + + let expected = expect![[r#" + generator client { + provider = "prisma-client-js" + first = "A" + second = "B" + } + "#]]; + + expected.assert_eq(&rendered1); + expected.assert_eq(&rendered2) + } }