From 5dd59aa192d6dd2ad887d51e26d0f64e3499c37e Mon Sep 17 00:00:00 2001 From: Moritz Halbritter Date: Wed, 4 Sep 2024 11:27:43 +0200 Subject: [PATCH] Add reflection metadata for Flyway 10.20.0 --- .../flyway-core/10.20.0/index.json | 4 + .../flyway-core/10.20.0/reflect-config.json | 197 ++++++++++++++++++ .../flyway-core/10.20.0/resource-config.json | 14 ++ metadata/org.flywaydb/flyway-core/index.json | 7 + tests/src/index.json | 6 + .../flyway-core/10.20.0/.gitignore | 4 + .../flyway-core/10.20.0/README.md | 12 ++ .../flyway-core/10.20.0/access-filter.json | 10 + .../flyway-core/10.20.0/build.gradle | 35 ++++ .../flyway-core/10.20.0/generate-metadata.sh | 4 + .../flyway-core/10.20.0/gradle.properties | 2 + .../flyway-core/10.20.0/settings.gradle | 13 ++ .../java/flyway/FixedResourceProvider.java | 47 +++++ .../src/test/java/flyway/FlywayTests.java | 47 +++++ .../native-image/test/resource-config.json | 13 ++ .../db/migration/V1__create_table.sql | 5 + .../db/migration/V2__alter_table.sql | 2 + .../flyway-core/10.20.0/user-code-filter.json | 10 + 18 files changed, 432 insertions(+) create mode 100644 metadata/org.flywaydb/flyway-core/10.20.0/index.json create mode 100644 metadata/org.flywaydb/flyway-core/10.20.0/reflect-config.json create mode 100644 metadata/org.flywaydb/flyway-core/10.20.0/resource-config.json create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/.gitignore create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/README.md create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/access-filter.json create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/build.gradle create mode 100755 tests/src/org.flywaydb/flyway-core/10.20.0/generate-metadata.sh create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/gradle.properties create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/settings.gradle create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/src/test/java/flyway/FixedResourceProvider.java create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/src/test/java/flyway/FlywayTests.java create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/META-INF/native-image/test/resource-config.json create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/db/migration/V1__create_table.sql create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/db/migration/V2__alter_table.sql create mode 100644 tests/src/org.flywaydb/flyway-core/10.20.0/user-code-filter.json diff --git a/metadata/org.flywaydb/flyway-core/10.20.0/index.json b/metadata/org.flywaydb/flyway-core/10.20.0/index.json new file mode 100644 index 000000000..11ac50cc5 --- /dev/null +++ b/metadata/org.flywaydb/flyway-core/10.20.0/index.json @@ -0,0 +1,4 @@ +[ + "reflect-config.json", + "resource-config.json" +] diff --git a/metadata/org.flywaydb/flyway-core/10.20.0/reflect-config.json b/metadata/org.flywaydb/flyway-core/10.20.0/reflect-config.json new file mode 100644 index 000000000..82dd413aa --- /dev/null +++ b/metadata/org.flywaydb/flyway-core/10.20.0/reflect-config.json @@ -0,0 +1,197 @@ +[ + { + "name": "org.flywaydb.core.api.migration.baseline.BaselineMigrationConfigurationExtension", + "condition": { + "typeReachable": "org.flywaydb.core.api.configuration.ClassicConfiguration" + }, + "allDeclaredFields": true + }, + { + "name": "org.flywaydb.core.api.migration.baseline.BaselineMigrationConfigurationExtension", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + }, + "allDeclaredFields": true, + "queryAllDeclaredConstructors": true, + "methods": [ + { + "name": "", + "parameterTypes": [ + ] + }, + { + "name": "getBaselineMigrationPrefix", + "parameterTypes": [ + ] + }, + { + "name": "setBaselineMigrationPrefix", + "parameterTypes": [ + "java.lang.String" + ] + } + ] + }, + { + "name": "org.flywaydb.core.extensibility.ConfigurationExtension", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + } + }, + { + "name": "org.flywaydb.core.extensibility.Plugin", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + } + }, + { + "name": "org.flywaydb.core.internal.command.clean.CleanModeConfigurationExtension", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + }, + "allDeclaredFields": true, + "queryAllDeclaredConstructors": true, + "methods": [ + { + "name": "", + "parameterTypes": [ + ] + }, + { + "name": "getClean", + "parameterTypes": [ + ] + }, + { + "name": "setClean", + "parameterTypes": [ + "org.flywaydb.core.internal.command.clean.CleanModel" + ] + } + ] + }, + { + "name": "org.flywaydb.core.internal.command.clean.CleanModel", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + }, + "allDeclaredFields": true, + "queryAllDeclaredConstructors": true + }, + { + "name": "org.flywaydb.core.internal.command.clean.SchemaModel", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + }, + "allDeclaredFields": true, + "queryAllDeclaredConstructors": true + }, + { + "name": "org.flywaydb.core.internal.configuration.extensions.DeployScriptFilenameConfigurationExtension", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + }, + "allDeclaredFields": true, + "queryAllDeclaredConstructors": true, + "methods": [ + { + "name": "", + "parameterTypes": [ + ] + }, + { + "name": "getScriptFilename", + "parameterTypes": [ + ] + }, + { + "name": "setScriptFilename", + "parameterTypes": [ + "java.lang.String" + ] + } + ] + }, + { + "name": "org.flywaydb.core.internal.configuration.extensions.PrepareScriptFilenameConfigurationExtension", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + }, + "allDeclaredFields": true, + "queryAllDeclaredConstructors": true, + "methods": [ + { + "name": "", + "parameterTypes": [ + ] + }, + { + "name": "getScriptFilename", + "parameterTypes": [ + ] + }, + { + "name": "setScriptFilename", + "parameterTypes": [ + "java.lang.String" + ] + } + ] + }, + { + "name": "org.flywaydb.core.internal.proprietaryStubs.LicensingConfigurationExtensionStub", + "condition": { + "typeReachable": "org.flywaydb.core.api.configuration.ClassicConfiguration" + }, + "allDeclaredFields": true + }, + { + "name": "org.flywaydb.core.internal.proprietaryStubs.PATTokenConfigurationExtensionStub", + "condition": { + "typeReachable": "org.flywaydb.core.api.configuration.ClassicConfiguration" + }, + "allDeclaredFields": true + }, + { + "name": "org.flywaydb.core.internal.publishing.PublishingConfigurationExtension", + "condition": { + "typeReachable": "org.flywaydb.core.api.configuration.ClassicConfiguration" + }, + "allDeclaredFields": true + }, + { + "name": "org.flywaydb.core.internal.publishing.PublishingConfigurationExtension", + "queryAllDeclaredMethods": true, + "condition": { + "typeReachable": "org.flywaydb.core.extensibility.ConfigurationExtension" + }, + "allDeclaredFields": true, + "queryAllDeclaredConstructors": true, + "methods": [ + { + "name": "", + "parameterTypes": [ + ] + }, + { + "name": "isPublishResult", + "parameterTypes": [ + ] + }, + { + "name": "setPublishResult", + "parameterTypes": [ + "boolean" + ] + } + ] + } +] diff --git a/metadata/org.flywaydb/flyway-core/10.20.0/resource-config.json b/metadata/org.flywaydb/flyway-core/10.20.0/resource-config.json new file mode 100644 index 000000000..b28217eba --- /dev/null +++ b/metadata/org.flywaydb/flyway-core/10.20.0/resource-config.json @@ -0,0 +1,14 @@ +{ + "resources": { + "includes": [ + { + "pattern": "\\Qorg/flywaydb/core/internal/version.txt\\E", + "condition": { + "typeReachable": "org.flywaydb.core.internal.license.VersionPrinter" + } + } + ] + }, + "bundles": [ + ] +} diff --git a/metadata/org.flywaydb/flyway-core/index.json b/metadata/org.flywaydb/flyway-core/index.json index a88828c66..284bd4819 100644 --- a/metadata/org.flywaydb/flyway-core/index.json +++ b/metadata/org.flywaydb/flyway-core/index.json @@ -1,6 +1,13 @@ [ { "latest": true, + "metadata-version": "10.20.0", + "module": "org.flywaydb:flyway-core", + "tested-versions": [ + "10.20.0" + ] + }, + { "metadata-version": "10.15.0", "module": "org.flywaydb:flyway-core", "tested-versions": [ diff --git a/tests/src/index.json b/tests/src/index.json index 350013325..df1570e47 100644 --- a/tests/src/index.json +++ b/tests/src/index.json @@ -412,6 +412,12 @@ "name" : "org.flywaydb:flyway-core", "versions" : [ "10.15.0" ] } ] +}, { + "test-project-path": "org.flywaydb/flyway-core/10.20.0", + "libraries": [ { + "name": "org.flywaydb:flyway-core", + "versions": [ "10.20.0" ] + } ] }, { "test-project-path" : "org.flywaydb/flyway-core/9.0.1", "libraries" : [ { diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/.gitignore b/tests/src/org.flywaydb/flyway-core/10.20.0/.gitignore new file mode 100644 index 000000000..c98c7875b --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/.gitignore @@ -0,0 +1,4 @@ +gradlew.bat +gradlew +gradle/ +build/ diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/README.md b/tests/src/org.flywaydb/flyway-core/10.20.0/README.md new file mode 100644 index 000000000..04bcbc001 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/README.md @@ -0,0 +1,12 @@ +The metadata has been generated by executing the following script: + +```bash +./generate-metadata.sh +``` + +The generated metadata can be found in the `build/native/agent-output/test` directory. + +Afterwards, the generated metadata has been cleaned: +- Remove path to test resources +- Remove `META-INF/services` entries +- Remove H2 references diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/access-filter.json b/tests/src/org.flywaydb/flyway-core/10.20.0/access-filter.json new file mode 100644 index 000000000..90a5450fc --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/access-filter.json @@ -0,0 +1,10 @@ +{ + "rules": [ + { + "excludeClasses": ".**" + }, + { + "includeClasses": "org.flywaydb.core.**" + } + ] +} diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/build.gradle b/tests/src/org.flywaydb/flyway-core/10.20.0/build.gradle new file mode 100644 index 000000000..41a757324 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/build.gradle @@ -0,0 +1,35 @@ +/* + * Copyright and related rights waived via CC0 + * + * You should have received a copy of the CC0 legalcode along with this + * work. If not, see . + */ +plugins { + id "org.graalvm.internal.tck" +} + +String libraryVersion = tck.testedLibraryVersion.get() + +dependencies { + testImplementation "org.flywaydb:flyway-core:$libraryVersion" + testImplementation 'com.h2database:h2:2.1.210' + testImplementation 'org.assertj:assertj-core:3.22.0' + testImplementation 'org.awaitility:awaitility:4.2.0' +} + +graalvmNative { + binaries { + test { + buildArgs.add('--no-fallback') + } + } + agent { + defaultMode = "conditional" + modes { + conditional { + userCodeFilterPath = "user-code-filter.json" + } + } + accessFilterFiles.from("access-filter.json") + } +} diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/generate-metadata.sh b/tests/src/org.flywaydb/flyway-core/10.20.0/generate-metadata.sh new file mode 100755 index 000000000..3be262b11 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/generate-metadata.sh @@ -0,0 +1,4 @@ +#!/usr/bin/env bash + +./gradlew clean +./gradlew test --tests "flyway.FlywayTests" -Pagent diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/gradle.properties b/tests/src/org.flywaydb/flyway-core/10.20.0/gradle.properties new file mode 100644 index 000000000..235e8aba6 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/gradle.properties @@ -0,0 +1,2 @@ +library.version=10.20.0 +metadata.dir=org.flywaydb/flyway-core/10.20.0/ diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/settings.gradle b/tests/src/org.flywaydb/flyway-core/10.20.0/settings.gradle new file mode 100644 index 000000000..b78d384f5 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/settings.gradle @@ -0,0 +1,13 @@ +pluginManagement { + def tckPath = Objects.requireNonNullElse( + System.getenv("GVM_TCK_TCKDIR"), + "../../../../tck-build-logic" + ) + includeBuild(tckPath) +} + +plugins { + id "org.graalvm.internal.tck-settings" version "1.0.0-SNAPSHOT" +} + +rootProject.name = 'flyway-core-tests' diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/java/flyway/FixedResourceProvider.java b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/java/flyway/FixedResourceProvider.java new file mode 100644 index 000000000..623451485 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/java/flyway/FixedResourceProvider.java @@ -0,0 +1,47 @@ +/* + * Copyright and related rights waived via CC0 + * + * You should have received a copy of the CC0 legalcode along with this + * work. If not, see . + */ +package flyway; + +import java.nio.charset.StandardCharsets; +import java.util.Collection; +import java.util.Collections; +import java.util.HashSet; +import java.util.Set; +import java.util.stream.Collectors; + +import org.flywaydb.core.api.ResourceProvider; +import org.flywaydb.core.api.resource.LoadableResource; +import org.flywaydb.core.internal.resource.classpath.ClassPathResource; + +/** + * This is needed as GraalVM doesn't support enumerating resources. It uses a hardcoded list of migrations. + */ +class FixedResourceProvider implements ResourceProvider { + private static final Set MIGRATIONS; + + static { + Set migrations = new HashSet<>(); + migrations.add("db/migration/V1__create_table.sql"); + migrations.add("db/migration/V2__alter_table.sql"); + MIGRATIONS = Collections.unmodifiableSet(migrations); + } + + @Override + public LoadableResource getResource(String name) { + if (!MIGRATIONS.contains(name)) { + return null; + } + return new ClassPathResource(null, name, getClass().getClassLoader(), StandardCharsets.UTF_8); + } + + @Override + public Collection getResources(String prefix, String[] suffixes) { + return MIGRATIONS.stream() + .map(file -> new ClassPathResource(null, file, getClass().getClassLoader(), StandardCharsets.UTF_8)) + .collect(Collectors.toList()); + } +} diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/java/flyway/FlywayTests.java b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/java/flyway/FlywayTests.java new file mode 100644 index 000000000..4a0caa64d --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/java/flyway/FlywayTests.java @@ -0,0 +1,47 @@ +/* + * Copyright and related rights waived via CC0 + * + * You should have received a copy of the CC0 legalcode along with this + * work. If not, see . + */ +package flyway; + +import java.nio.charset.StandardCharsets; + +import javax.sql.DataSource; + +import org.flywaydb.core.Flyway; +import org.flywaydb.core.api.configuration.Configuration; +import org.flywaydb.core.api.configuration.FluentConfiguration; +import org.flywaydb.core.api.output.MigrateResult; +import org.h2.jdbcx.JdbcDataSource; +import org.junit.jupiter.api.Test; + +import static org.assertj.core.api.Assertions.assertThat; + +public class FlywayTests { + + @Test + void migrate() { + DataSource dataSource = getDataSource(); + + Configuration configuration = new FluentConfiguration() + .dataSource(dataSource) + .encoding(StandardCharsets.UTF_8) + .resourceProvider(new FixedResourceProvider()); + + Flyway flyway = new Flyway(configuration); + MigrateResult migration = flyway.migrate(); + + assertThat(migration.success).isTrue(); + assertThat(migration.migrationsExecuted).isEqualTo(2); + } + + private DataSource getDataSource() { + JdbcDataSource dataSource = new JdbcDataSource(); + dataSource.setUrl("jdbc:h2:mem:test"); + dataSource.setUser("user"); + dataSource.setPassword("password"); + return dataSource; + } +} diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/META-INF/native-image/test/resource-config.json b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/META-INF/native-image/test/resource-config.json new file mode 100644 index 000000000..427b8ed40 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/META-INF/native-image/test/resource-config.json @@ -0,0 +1,13 @@ +{ + "bundles": [], + "resources": { + "includes": [ + { + "pattern": "\\Qdb/migration/V1__create_table.sql\\E" + }, + { + "pattern": "\\Qdb/migration/V2__alter_table.sql\\E" + } + ] + } +} diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/db/migration/V1__create_table.sql b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/db/migration/V1__create_table.sql new file mode 100644 index 000000000..5e35ac71d --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/db/migration/V1__create_table.sql @@ -0,0 +1,5 @@ +CREATE TABLE test +( + id INT PRIMARY KEY, + title VARCHAR NOT NULL +); diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/db/migration/V2__alter_table.sql b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/db/migration/V2__alter_table.sql new file mode 100644 index 000000000..ed568f6e7 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/src/test/resources/db/migration/V2__alter_table.sql @@ -0,0 +1,2 @@ +ALTER TABLE test + ADD COLUMN name INT NOT NULL DEFAULT 1; diff --git a/tests/src/org.flywaydb/flyway-core/10.20.0/user-code-filter.json b/tests/src/org.flywaydb/flyway-core/10.20.0/user-code-filter.json new file mode 100644 index 000000000..b75d5f693 --- /dev/null +++ b/tests/src/org.flywaydb/flyway-core/10.20.0/user-code-filter.json @@ -0,0 +1,10 @@ +{ + "rules": [ + { + "includeClasses": "org.flywaydb.core.**" + }, + { + "includeClasses": "flyway.FlywayTests" + } + ] +}