2024-09-19 14:19:46 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
runCommand,
|
|
|
|
prisma,
|
|
|
|
prisma-engines,
|
|
|
|
sqlite-interactive,
|
|
|
|
}:
|
2022-05-18 14:49:53 +00:00
|
|
|
|
|
|
|
let
|
|
|
|
prismaMajorVersion = lib.versions.majorMinor prisma.version;
|
2024-09-19 14:19:46 +00:00
|
|
|
enginesMajorVersion = lib.versions.majorMinor prisma-engines.version;
|
2022-05-18 14:49:53 +00:00
|
|
|
in
|
2024-09-19 14:19:46 +00:00
|
|
|
runCommand "prisma-cli-tests"
|
|
|
|
{
|
|
|
|
nativeBuildInputs = [
|
|
|
|
prisma
|
|
|
|
sqlite-interactive
|
|
|
|
];
|
|
|
|
meta.timeout = 60;
|
|
|
|
}
|
2022-05-18 14:49:53 +00:00
|
|
|
''
|
|
|
|
mkdir $out
|
|
|
|
cd $out
|
|
|
|
|
|
|
|
if [ "${prismaMajorVersion}" != "${enginesMajorVersion}" ]; then
|
2024-09-19 14:19:46 +00:00
|
|
|
echo "prisma in version ${prismaMajorVersion} and prisma-engines in ${enginesMajorVersion}. Major versions must match."
|
2022-05-18 14:49:53 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Ensure CLI runs
|
|
|
|
prisma --help > /dev/null
|
|
|
|
|
|
|
|
# Init a new project
|
|
|
|
prisma init > /dev/null
|
|
|
|
|
|
|
|
# Create a simple data model
|
|
|
|
cat << EOF > prisma/schema.prisma
|
|
|
|
datasource db {
|
|
|
|
provider = "sqlite"
|
|
|
|
url = "file:test.db"
|
|
|
|
}
|
|
|
|
|
|
|
|
generator js {
|
|
|
|
provider = "prisma-client-js"
|
|
|
|
}
|
|
|
|
|
|
|
|
model A {
|
|
|
|
id Int @id @default(autoincrement())
|
|
|
|
b String @default("foo")
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
# Format
|
|
|
|
prisma format > /dev/null
|
|
|
|
|
|
|
|
# Create the database
|
|
|
|
prisma db push --skip-generate > /dev/null
|
|
|
|
|
|
|
|
# The database file should exist and be a SQLite database
|
|
|
|
sqlite3 prisma/test.db "SELECT id, b FROM A" > /dev/null
|
|
|
|
|
|
|
|
# Introspect the database
|
|
|
|
prisma db pull > /dev/null
|
|
|
|
''
|