From 4abf678fedd434470d0f203a5080546404896704 Mon Sep 17 00:00:00 2001 From: Denver Coneybeare Date: Sat, 7 Dec 2024 00:17:07 -0500 Subject: [PATCH 1/4] dataconnect: demo: make codegen gradle task cacheable (#6571) --- firebase-dataconnect/demo/build.gradle.kts | 35 +++++++++++----------- 1 file changed, 17 insertions(+), 18 deletions(-) diff --git a/firebase-dataconnect/demo/build.gradle.kts b/firebase-dataconnect/demo/build.gradle.kts index 6e705b343ba..78465a0df41 100644 --- a/firebase-dataconnect/demo/build.gradle.kts +++ b/firebase-dataconnect/demo/build.gradle.kts @@ -108,10 +108,12 @@ spotless { } } -@DisableCachingByDefault(because = "Code generation is very fast and not worth caching") +@CacheableTask abstract class DataConnectGenerateSourcesTask : DefaultTask() { - @get:InputDirectory abstract val inputDirectory: Property + @get:InputDirectory + @get:PathSensitive(PathSensitivity.RELATIVE) + abstract val inputDirectory: Property @get:Input abstract val firebaseToolsVersion: Property @@ -270,22 +272,19 @@ run { val path = providers.environmentVariable("PATH") firebaseToolsVersion = - providers.provider { - providers - .exec { - DataConnectGenerateSourcesTask.configureFirebaseCommand( - this, - firebaseCommand = firebaseCommand.get(), - nodeExecutableDirectory = nodeExecutableDirectory.orNull, - path = path.orNull, - ) - args("--version") - } - .standardOutput - .asText - .get() - .trim() - } + providers + .exec { + DataConnectGenerateSourcesTask.configureFirebaseCommand( + this, + firebaseCommand = firebaseCommand.get(), + nodeExecutableDirectory = nodeExecutableDirectory.orNull, + path = path.orNull, + ) + args("--version") + } + .standardOutput + .asText + .map { it.trim() } workDirectory = layout.buildDirectory.dir(name) } From 7b828fc520bb8b26a446c3eb1eada66eaab2ead8 Mon Sep 17 00:00:00 2001 From: Denver Coneybeare Date: Sat, 7 Dec 2024 09:18:14 -0500 Subject: [PATCH 2/4] dataconnect: DataConnectExecutableVersions.json updated with versions 1.7.1, 1.7.2, 1.7.3, and 1.7.4 (#6579) --- .../plugin/DataConnectExecutableVersions.json | 74 ++++++++++++++++++- 1 file changed, 73 insertions(+), 1 deletion(-) diff --git a/firebase-dataconnect/gradleplugin/plugin/src/main/resources/com/google/firebase/dataconnect/gradle/plugin/DataConnectExecutableVersions.json b/firebase-dataconnect/gradleplugin/plugin/src/main/resources/com/google/firebase/dataconnect/gradle/plugin/DataConnectExecutableVersions.json index 886c8eeacb1..58d4e6fae79 100644 --- a/firebase-dataconnect/gradleplugin/plugin/src/main/resources/com/google/firebase/dataconnect/gradle/plugin/DataConnectExecutableVersions.json +++ b/firebase-dataconnect/gradleplugin/plugin/src/main/resources/com/google/firebase/dataconnect/gradle/plugin/DataConnectExecutableVersions.json @@ -1,5 +1,5 @@ { - "defaultVersion": "1.7.0", + "defaultVersion": "1.7.4", "versions": [ { "version": "1.3.4", @@ -288,6 +288,78 @@ "os": "linux", "size": 25272472, "sha512DigestHex": "795c3f63a3c78b94204ae8c525227f3295a02cd90e553f52bde543029a91f68da0d17653cc6b4c863ed778104fd2baa97a729f80ab4bd54dd5dd4f5e15354b7a" + }, + { + "version": "1.7.1", + "os": "windows", + "size": 25788928, + "sha512DigestHex": "e31515c8dc138775125998a37f7bf4abf625d2d6336b10b66a05cc3d4df6055862e27e74f3abee73295d2bee15f5b789bca43cd12df44219b5636d2c59fab939" + }, + { + "version": "1.7.1", + "os": "macos", + "size": 25359104, + "sha512DigestHex": "cfb72065a37aaf7093ae4cac5480b90079b5eb9dc04ea3f25f62fed20b5627a289681796a422df77296e75b9492a0d7405983fe1906e2aa1fe299e303f6a651e" + }, + { + "version": "1.7.1", + "os": "linux", + "size": 25272472, + "sha512DigestHex": "888a40b95489071bfa40596d7d02dd91dff85ef6d15bda75d29caec3a76cc1deaa52aa2a95c0760f4bc97f7905e3222f0c2fdb6baccb8de35c4036c135e541d4" + }, + { + "version": "1.7.2", + "os": "windows", + "size": 25441792, + "sha512DigestHex": "406aa5e815a8371b0bf6d5205d10d89a38e981eece2a033f6442a71c1b71c3cb3bf340c830f3dc228ed8acad7878818a07731236a631cfe5b932fef8a6c3972d" + }, + { + "version": "1.7.2", + "os": "macos", + "size": 25019136, + "sha512DigestHex": "3300a5b3e5342fc274bc09823cf3e06c6a7b7eca23048d320ff99ff305d7b96e0ca9d7e0cde30356d539684f65cd8aa43b1ba2041fdb4418cc171663221cf7ea" + }, + { + "version": "1.7.2", + "os": "linux", + "size": 24932504, + "sha512DigestHex": "1fbc868e0549180910a9c3dee0e26d042a1a470312a4c66442fe44fa7878acfc1a9b8928f5699b144fa9bb7a3dea2d4ab20f307be49a3ea7b562a2217610ccf4" + }, + { + "version": "1.7.3", + "os": "windows", + "size": 25641984, + "sha512DigestHex": "5d1da00307d3a7a446a0a6117bde6833b868626c08bc7a53e8abb989c83cb8fabec2de930c2fe45336388f0a0b8c954fe00fd5acea3d0a296a9d6b0e6659c873" + }, + { + "version": "1.7.3", + "os": "macos", + "size": 25211648, + "sha512DigestHex": "b6ccea65bb8596535d93b6e8a847c571c79da7cff374f54971608e9751134a618d69c4202aebcdb657ccd840ac4a2e7b98c189fa36323cf0c4816a6ca6a48c00" + }, + { + "version": "1.7.3", + "os": "linux", + "size": 25125016, + "sha512DigestHex": "2f4c911086f83f8f46264e37b0c1840239f8a28283e529bc476f6b7382acd83e1326dadf4e4e84c85cb5bf2d72f1369875be4c197bdd8cfc8f37cdc1cd2cd228" + }, + { + "version": "1.7.4", + "os": "windows", + "size": 25707520, + "sha512DigestHex": "cd147b8c8731b98c55979fb600de9ec74f28b619d38649de18d3a5982169a241209acaefe26f262f23b1df7511b1d6c4734760ef7f54acdcd3fae262f5dc4a85" + }, + { + "version": "1.7.4", + "os": "macos", + "size": 25277184, + "sha512DigestHex": "93a93b215e02f3f8f16f45f665f5dcd42a112240031cb15db9e17fdfb919f189abf4bf9f3afcc8d34c5adcf4b802f839accb185b1ee93848c68267d2d3455928" + }, + { + "version": "1.7.4", + "os": "linux", + "size": 25190552, + "sha512DigestHex": "abbfe1f4973c0bc0f6a89d618886ccbb09bd8fd34b66c142a67c9899b70b600ebbd5f96f15a65fc78096b3adbb18708786b181ba7f51bc85314b62888ba01293" } ] } \ No newline at end of file From a0ec5442ec3edc7352302a09d628f6af637c8d0f Mon Sep 17 00:00:00 2001 From: Denver Coneybeare Date: Mon, 9 Dec 2024 13:57:17 -0500 Subject: [PATCH 3/4] Fix "duplicate class" errors when running `./gradlew :appcheck:firebase-appcheck-debug:deviceCheck` (#6581) --- appcheck/firebase-appcheck-debug/firebase-appcheck-debug.gradle | 1 + 1 file changed, 1 insertion(+) diff --git a/appcheck/firebase-appcheck-debug/firebase-appcheck-debug.gradle b/appcheck/firebase-appcheck-debug/firebase-appcheck-debug.gradle index b1b546d1dfc..44a14355d03 100644 --- a/appcheck/firebase-appcheck-debug/firebase-appcheck-debug.gradle +++ b/appcheck/firebase-appcheck-debug/firebase-appcheck-debug.gradle @@ -53,6 +53,7 @@ dependencies { api 'com.google.firebase:firebase-annotations:16.2.0' api 'com.google.firebase:firebase-common:21.0.0' api 'com.google.firebase:firebase-components:18.0.0' + implementation platform(libs.kotlin.bom) implementation libs.playservices.base implementation libs.playservices.tasks From b164139613deb7f0d00615e276b37a1dd9ab083a Mon Sep 17 00:00:00 2001 From: Denver Coneybeare Date: Mon, 9 Dec 2024 15:33:53 -0500 Subject: [PATCH 4/4] dataconnect: demo: upgrade firebase-tools to v13.28.0 (#6577) --- .github/workflows/dataconnect_demo_app.yml | 2 +- .../firebase/dataconnect/connector/operations.gql | 14 ++++++++++++++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/.github/workflows/dataconnect_demo_app.yml b/.github/workflows/dataconnect_demo_app.yml index 13492847c93..7ce51814b4d 100644 --- a/.github/workflows/dataconnect_demo_app.yml +++ b/.github/workflows/dataconnect_demo_app.yml @@ -17,7 +17,7 @@ on: env: FDC_NODE_VERSION: ${{ inputs.nodeVersion || '20' }} - FDC_FIREBASE_TOOLS_VERSION: ${{ inputs.firebaseToolsVersion || '13.25.0' }} + FDC_FIREBASE_TOOLS_VERSION: ${{ inputs.firebaseToolsVersion || '13.28.0' }} FDC_JAVA_VERSION: ${{ inputs.javaVersion || '17' }} FDC_FIREBASE_TOOLS_DIR: ${{ github.workspace }}/firebase-tools FDC_FIREBASE_COMMAND: ${{ github.workspace }}/firebase-tools/node_modules/.bin/firebase diff --git a/firebase-dataconnect/demo/firebase/dataconnect/connector/operations.gql b/firebase-dataconnect/demo/firebase/dataconnect/connector/operations.gql index 85c30c43329..9eedec56a7a 100644 --- a/firebase-dataconnect/demo/firebase/dataconnect/connector/operations.gql +++ b/firebase-dataconnect/demo/firebase/dataconnect/connector/operations.gql @@ -48,3 +48,17 @@ query GetItemByKey( any } } + +# This mutation exists only as a workaround for b/382688278 where the following +# compiler error will otherwise result when compiling the generated code: +# Serializer has not been found for type 'java.util.UUID'. To use context +# serializer as fallback, explicitly annotate type or property with @Contextual +# This bug first appeared in v1.7.1 of the Data Connect Toolkit CLI, which +# started to be used in firebase-tools v13.26.0 +# (https://github.com/firebase/firebase-tools/releases/tag/v13.26.0). +# This mutation can be removed from this file once the fix is released, which will +# likely be version 1.7.4 of the Data Connect Toolkit CLI (v13.28.1 of firebase- +# tools). +mutation WorkaroundForBug382688278( $id: UUID!) { + zwda6x9zyy_insert(data: { id: $id }) +}