From 0ba77cbcbf598cc3783391b45b760fe612a72eb8 Mon Sep 17 00:00:00 2001 From: David Nestorovic Date: Tue, 19 Nov 2024 14:57:00 +0100 Subject: [PATCH 01/26] Restyle docs landing page --- docs/src/docs/asciidoc/changelog.adoc | 478 +++++++++++++++++ .../images/GraalVM-icon.svg} | 0 docs/src/docs/asciidoc/css/images/Grabbit.svg | 53 ++ docs/src/docs/asciidoc/css/landing-page.css | 33 ++ docs/src/docs/asciidoc/docinfo-footer.html | 3 +- docs/src/docs/asciidoc/index.adoc | 503 +----------------- 6 files changed, 588 insertions(+), 482 deletions(-) create mode 100644 docs/src/docs/asciidoc/changelog.adoc rename docs/src/docs/asciidoc/{img/GraalVM-rgb.svg => css/images/GraalVM-icon.svg} (100%) create mode 100644 docs/src/docs/asciidoc/css/images/Grabbit.svg create mode 100644 docs/src/docs/asciidoc/css/landing-page.css diff --git a/docs/src/docs/asciidoc/changelog.adoc b/docs/src/docs/asciidoc/changelog.adoc new file mode 100644 index 000000000..37f40952a --- /dev/null +++ b/docs/src/docs/asciidoc/changelog.adoc @@ -0,0 +1,478 @@ +[[changelog]] +== Changelog + +=== Release 0.10.3 + +- Remove usage of macro from merger tool initialization and throw better error if executable does not exist +- Add support for the new reachability-metadata.json config file +- Remove custom post-processing task for filtering config files entries and use access-filter.json instead + +==== Gradle plugin + +- Add retries when downloading the metadata repository when using a URL directly + +==== Maven plugin + +- Add retries when downloading the metadata repository when using a URL directly + + +=== Release 0.10.2 + +- Fix class path directory analyzer +- Update Reachability Metadata repository version + +==== Gradle plugin + +- Update Default Target Directory for MetadataCopy Task + +==== Maven plugin + +- Update Getting Started with Maven Plugin doc +- Delete old stale args file +- Add a parameter to be able to skip build native for pom type modules, leave it as false per default for backward compat + +=== Release 0.10.1 + +- Mark additional JUnit 5 types for build-time initialization for compatibility with Native Image's `--strict-image-heap` option. + + +=== Release 0.10.0 + +- Update version of GraalVM dependency to 22.3.5 + +==== Gradle plugin + +- Update plugin to use metadata repository by default. Metadata repository <> + +==== Maven plugin + +- Update plugin to use metadata repository by default. Metadata repository <> + + +=== Release 0.9.28 + +* Fix path escaping problem for Windows users +* Fix and improve major JDK version detection. + +==== Gradle plugin + +- Remove use of deprecated `getConvention` APIs + +=== Release 0.9.27 + +* Update JUnit configuration for native testing on GraalVM for JDK 21 with `--strict-image-heap` mode. + +=== Release 0.9.26 + +* Relax GraalVM version check for dev versions +* Prepare plugins for release of _GraalVM for JDK 21_. They no longer deploy any experimental options. +* Bump Java compliance of the plugins from Java 8+ to Java 11+. +* Fix compatibility with Maven 3.9. + +==== Gradle plugin + +* Fix compatibility with Gradle 8.3 + +=== Release 0.9.25 + +* Upgrade metadata to 0.3.4 + +=== Release 0.9.24 + +* Upgrade metadata to 0.3.3 + +==== Gradle plugin + +* Add support for PGO + +=== Release 0.9.23 + +* Upgrade metadata to 0.3.2 +* Display the GraalVM logo on the generated NBT docs + +==== Gradle plugin + +- Remove use of GFileUtils +- Fix "collect reachability metadata" with config cache + +=== Release 0.9.22 + +* Upgrade metadata to 0.3.0 +* Add support for default-for attribute + +==== Gradle plugin + +- Fix lookup of metadata repository + +=== Release 0.9.21 + +* Deprecate `requiredVersion` check without replacement. + +==== Gradle plugin + +- Bump minimal version of Gradle to 7.4 +- Fix compatibility with Gradle's https://docs.gradle.org/8.0.2/userguide/configuration_cache.html#header[configuration cache] (requires Gradle 7.5+) +- Remove use of deprecated Gradle APIs +- [Behavior change] Toolchain detection is now disabled by default + +==== Maven plugin + +- Add a new `native:write-args-file` goal that can be used to write the arguments passed to `native-image` to a file + +=== Release 0.9.20 + +==== Gradle plugin + +- Fix `collectReachabilityMetadata` not being thread-safe +- Add an option to configure the maximum number of images which can be built in parallel +- Fix GraalVM version check being too strict + +==== Maven plugin + +- Add agent modes to Maven plugin + +=== Release 0.9.19 + +==== Gradle plugin + +- Fix `nativeCompile` being out-of-date whenever native runtime arguments change +- Fix GraalVM metadata repository not downloaded from project repositories by default + +==== Maven plugin + +=== Release 0.9.18 + +* Trim GraalVM version to fix Windows support +* Add tests for NativeImageUtils.escapeArg +* Do not escape quoted regexp args when using argsfile +* Upgrade to GraalVM metadata repository 0.2.5 + +=== Release 0.9.17 + +* Add a `requiredVersion` property to check the minimal GraalVM version +* Make GraalVM installation check lazy + +=== Release 0.9.16 + +* Fixed regression with a reachability-metadata repository + +=== Release 0.9.15 + +* Upgrade to GraalVM metadata repository 0.2.3. +* Ship the metadata repository as an artifact alongside the plugin +* Add ability to collect GraalVM metadata of dependencies to a custom location + +==== Gradle plugin + +* Improved diagnostics to help users figure out what GraalVM toolchain was selected + +=== Release 0.9.14 + +==== Gradle plugin +* Add ability to set environment variables to the native image builder process +* Argument files are now stored in the `build` directory (workaround for absolute path issue on Windows with older GraalVM versions) + +==== Maven plugin +* Added `native:compile` forking goal that can be started from the command line as `mvn native:compile`. +* Deprecated `build` goal in favour of `compile-no-fork` goal. This goal should now be used for attaching to the `package` phase in `pom.xml`. Attaching the `build` goal will (for now) produce a runtime warning. +* Argument files are now stored in the `target` directory (workaround for absolute path issue on Windows with older GraalVM versions). +* Default and test outputs are now much less noisy. +* When running tests in JVM mode with the native-image-agent, GraalVM's `java` executable is now always used. +* Maven plugin now shouldn't require that JVM running it must be GraalVM. + +=== Release 0.9.13 + +==== Gradle plugin +* Reverted a change in the `NativeImagePlugin` that removed publicly accessible constants. This should prevent breakage of external plugins. + +==== JUnit testing support +* Adapted the JUnit automatic metadata registration to changes in annotation handling on newer native image versions. + +=== Release 0.9.12 + +==== Gradle plugin +* Completely reworked agent support - **BREAKING CHANGE** +* The agent block is no longer tied to the target binary. +* The agent can now instrument any task that extends `JavaForkOptions`. +* Introduced the `metadataCopy` task. +* Introduced the concept of agent modes. +** Under the hood, the agent mode dictates what options are passed to the agent and how metadata produced by multiple runs get merged. +* Added `excludeConfig` configuration option that allows skipping of configuration files that are present in dependencies. +* `useArgFile` is now set to true by default only on Windows. +* Added `quickBuild` configuration option. + +==== Maven plugin +* Added support for GraalVM Reachability Metadata Repository. +* Completely reworked Maven plugin (should fix many of previous issues and inconsistencies between main and test builds). +* Added `classesDirectory`, `debug`, `fallback`, `verbose`, `sharedLibrary`, `configurationFileDirectories`, `excludeConfig`, `quickBuild`, and `jvmArgs` properties in order to match those present in the Gradle plugin. ++ +See <> for more information. +* `useArgFile` is now set to true by default only on Windows. +* Changed lookup order for `native-image` discovery -- `GRAALVM_HOME`, `JAVA_HOME`, `PATH`. + +=== Release 0.9.11 + +==== Maven plugin + +* Fix long classpath issue under Windows when running native tests +* Inherit environment variables and system properties from the surefire plugin configuration when executing tests +* Fix invocation of `native-image` when classpath contains spaces + +==== Gradle plugin + +* Add support for environment variables in native test execution +* Fix invocation of `native-image` when classpath contains spaces +* Add experimental support for the JVM reachability metadata repository + +=== Release 0.9.10 + +==== Maven plugin + +* Native testing support can now be explicitly disabled via `skipNativeTests`. + - See <> for details. +* Fixed race condition which prevented the agent files to be generated properly if tests were executed concurrently +* Documented version compatibility for the JUnit Platform and Maven Surefire plugin. + - See <> for details. +* Add support for long classpath by using an argument file when invoking `native-image` + +==== Gradle plugin + +* Fixed `nativeRun` not working properly under Windows +* Fixed race condition which prevented the agent files to be generated properly if tests were executed concurrently +* Add support for long classpath by using an argument file when invoking `native-image` + +=== Release 0.9.9 + +==== Gradle plugin + +* Fixed resource inference not working on custom binaries +* Fixed `disableToolchainDetection` not working if a GraalVM installation isn't present. Please use `graalvmNative.toolchainDetection.set(false)` instead. + +=== Release 0.9.8 + +==== Gradle plugin + +* [Breaking change] The `agent` option has been replaced with an `agent { ... }` configuration block which includes an `enabled` property. +* Toolchain support can now be disabled altogether, which can be useful when using GraalVM Enterprise Edition. + - See <> for details. +* Fixed a bug when using a _fat jar_ which assumed that all entries to be repackaged were jars. +* Agent options are now configurable. + - Note that the `experimental-class-loader-support` agent option is no longer added by default. + - See <> for details. +* Added an option to perform resource detection in classpath entries which contain a `native-image/resource-config.json` file. + +==== Maven plugin + +* The agent can now be enabled in the POM. + - See <> for details. +* Agent options are now configurable. + - Note that the `experimental-class-loader-support` agent option is no longer added by default. + - See <> for details. +* Added an option to perform resource detection in classpath entries which contain a `native-image/resource-config.json` file. + +==== JUnit Platform Native + +* Builds now correctly fail if a container-level extension or lifecycle method fails -- + for example, if an `@BeforeAll` method in a JUnit Jupiter test class throws an exception. +* Builds no longer fail when tests are aborted -- for example, via a failed assumption. +* Improved documentation for JUnit Platform and Maven Surefire support in the plugins. + +=== Release 0.9.7.1 + +==== Bugfixes + +- Fixed https://github.com/graalvm/native-build-tools/issues/144[Maven plugin configuration not applied if declared in a parent POM]. + +=== Release 0.9.7 + +Release didn't include any fixes. + +=== Release 0.9.6 + +==== Upgrade to JUnit 5.8 + +The plugins now depend on JUnit 5.8 which provides an official test listener which is used by these plugins. +As a consequence, Maven users will have to configure their builds to enable the plugin extensions: + +```xml + + org.graalvm.buildtools + native-maven-plugin + ${native.maven.plugin.version} + true + ... + +``` + +The dependency on `junit-platform-native` which used to be required pre-0.9.6 can now safely be removed. + +For Gradle users, there's no impact on the configuration, however a good consequence is that the `junit-native-platform` dependency no longer leaks into your application's classpath. + +==== Agent support for Maven plugin + +The Maven plugin now supports the GraalVM agent to generate configuration files. +Please refer to the <> for details. + +==== Disabling testing support + +The Gradle plugin now provides an option to disable testing support. +This can be useful if the test framework you are using doesn't work with this plugin or that you simply don't want to execute tests natively. + +To disable tests, use the `graalvmNative` configuration block: + +```kotlin +graalvmNative { + testSupport.set(false) +} +``` + +==== Configuring additional test images + +The Gradle plugin now supports building multiple test images, which can be used to execute tests natively for more kinds of tests: integration tests, functional tests, ... + +For more information, please refer to <> + +=== Release 0.9.5 + +This release contains, in preparation for supporting more images in the Gradle plugin: + +- The `nativeBuild` and `nativeTest` extensions are now deprecated. A top-level container for configuring native images has been introduced. Instead of: + +[source,groovy] +---- +nativeBuild { + verbose = true +} +---- + +you need to use: + +[source,groovy] +---- +graalvmNative { + binaries { + main { + verbose = true + } + } +} +---- + +and instead of: + +[source,groovy] +---- +nativeTest { + buildArgs("...") +} +---- + +you need to use: + +[source,groovy] +---- +graalvmNative { + binaries { + test { + verbose = true + } + } +} +---- + +- The `nativeBuild` task has been renamed to `nativeCompile`. +- The `nativeTestBuild` task has been renamed to `nativeTestCompile`. + +Both `nativeBuild` and `nativeTestBuild` task invocations are still supported but deprecated and will be removed in a future release. + +=== Release 0.9.4 + +This release works around a limitation for Windows users who encounter an issue with long classpath entries on CLI: the Gradle plugin will now automatically handle this problem by creating a fat jar instead of passing all entries on classpath (this behavior can be <>) if needed). +Maven users will have to <> to use shading. + +In addition to this, we're now publishing development snapshots of this plugin. For Gradle, you will need to declare this repository in your settings.gradle(.kts) file: + +[source,groovy] +---- +pluginManagement { + plugins { + id 'org.graalvm.buildtools.native' version '0.9.5-SNAPSHOT' + } + repositories { + maven { + url "https://raw.githubusercontent.com/graalvm/native-build-tools/snapshots" + } + gradlePluginPortal() + } +} +---- + +For Maven, you need to use this repository configuration: + +[source,xml] +---- + + + graalvm-native-build-tools-snapshots + GraalVM native-build-tools Snapshots + https://raw.githubusercontent.com/graalvm/native-build-tools/snapshots + + false + + + true + + + +---- + +=== Release 0.9.3 + +This release contains: + +- Fix for mainClass not being optional (Gradle plugin) +- Fix for Gradle < 7 failing to determine GraalVM toolchain +- Gradle plugin now registers proper groups +- Automatic native-image tool fetching via gu (Gradle plugin) +- FIxed issue where nativeTest would fail when tests are annotated with Timeout +- Added a sharedLibrary configuration option for Gradle plugin +- Removed broken server configuration option from Gradle plugin +- Added a documentation website with proper CI integration + +In addition to those improvements, several behind-the-scenes changes were made: + +- Introduced "Dockerless" Maven plugin functional testing +- Parallelized Gradle testing in CI +- Replaced groovy-json with jackson-databind for JSON handling +- Fixed Github Actions syntax to enable manual workflow invoking + +=== Release 0.9.2 + +This release contains: + +- Revamped Gradle plugin that is now a lot more idiomatic. +- Fixes for several issues regarding JUnit testing. +- Removal of Test Discovery mode from the Maven plugin. +- Fix for Maven creating empty test images when no tests are present. +- Added support for Kotlin tests in Gradle. + +In addition to those improvements, several behind-the-scenes changes were made in order to ensure better compatibility moving forward: + +- Test coverage has been greatly improved for all subprojects. +- Build tooling for this repository has been improved significantly. + +Note that there has been a breaking change in the Gradle plugin - `persistConfig` configuration option was removed. +Using said option will cause existing builds to break, so users are advised to remove it from their configuration prior to upgrading. +System property `-DpersistConfig` will have no effect going forward. + +=== Release 0.9.1 + +This release contains: + +- Fixes for most of the known issues regarding Gradle and Maven plugins +- Massively improved automatic JUnit support as well as initial JUnit Vintage support +- Improved JavaDoc and tests for the Gradle plugin + +=== Release 0.9.0 + +Initial release diff --git a/docs/src/docs/asciidoc/img/GraalVM-rgb.svg b/docs/src/docs/asciidoc/css/images/GraalVM-icon.svg similarity index 100% rename from docs/src/docs/asciidoc/img/GraalVM-rgb.svg rename to docs/src/docs/asciidoc/css/images/GraalVM-icon.svg diff --git a/docs/src/docs/asciidoc/css/images/Grabbit.svg b/docs/src/docs/asciidoc/css/images/Grabbit.svg new file mode 100644 index 000000000..2242e9970 --- /dev/null +++ b/docs/src/docs/asciidoc/css/images/Grabbit.svg @@ -0,0 +1,53 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/docs/src/docs/asciidoc/css/landing-page.css b/docs/src/docs/asciidoc/css/landing-page.css new file mode 100644 index 000000000..66a44fc6e --- /dev/null +++ b/docs/src/docs/asciidoc/css/landing-page.css @@ -0,0 +1,33 @@ +body { + background: linear-gradient(rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.9)); + color: white; +} + +#header>h1:first-child { + color: white; + font-weight: 600; +} + +#header>.details { + color: white; +} + +#footer { + background: rgba(0, 0, 0, 0.2); +} + +h3 { + color: #ffc107; +} + +p { + color: white; +} + +a { + color: #00758F; +} + +.admonitionblock td.icon .icon-tip::before { + color: white; +} diff --git a/docs/src/docs/asciidoc/docinfo-footer.html b/docs/src/docs/asciidoc/docinfo-footer.html index 0ec25b33b..03dc4635a 100644 --- a/docs/src/docs/asciidoc/docinfo-footer.html +++ b/docs/src/docs/asciidoc/docinfo-footer.html @@ -1,7 +1,8 @@ + diff --git a/docs/src/docs/asciidoc/index.adoc b/docs/src/docs/asciidoc/index.adoc index 703456ede..cc83de422 100644 --- a/docs/src/docs/asciidoc/index.adoc +++ b/docs/src/docs/asciidoc/index.adoc @@ -1,496 +1,37 @@ = Native Build Tools The GraalVM team -The {doctitle} project provides plugins for different build tools to add support for building and testing native applications written in Java (or any other language compiled to JVM bytecode). +The {doctitle} project provides plugins for different build tools to add support for building and testing native applications written in Java +(or any other language compiled to JVM bytecode) using the https://www.graalvm.org/reference-manual/native-image/[GraalVM Native Image]. +At the moment, you can build your native projects using our Gradle or Maven plugin. -Most notably, this is the official source for integrating with the https://www.graalvm.org/reference-manual/native-image/[GraalVM Native Image]. - -Please refer to the following pages for build tool specific documentation: - -- The <> -- The <> - -This release of Native Build Tools ships with the GraalVM reachability metadata repository release {metadata-repository-version}. - -If you are interested in contributing, please refer to the https://github.com/graalvm/native-build-tools[Git repository]. +Each plugin takes metadata for available libraries from the https://github.com/oracle/graalvm-reachability-metadata[GraalVM reachability metadata repository] +to provide better experience during the development of your native project. If you are using alternative build systems, see <>. -[[changelog]] -== Changelog - -=== Release 0.10.3 - -- Remove usage of macro from merger tool initialization and throw better error if executable does not exist -- Add support for the new reachability-metadata.json config file -- Remove custom post-processing task for filtering config files entries and use access-filter.json instead - -==== Gradle plugin - -- Add retries when downloading the metadata repository when using a URL directly - -==== Maven plugin - -- Add retries when downloading the metadata repository when using a URL directly - - -=== Release 0.10.2 - -- Fix class path directory analyzer -- Update Reachability Metadata repository version - -==== Gradle plugin - -- Update Default Target Directory for MetadataCopy Task - -==== Maven plugin - -- Update Getting Started with Maven Plugin doc -- Delete old stale args file -- Add a parameter to be able to skip build native for pom type modules, leave it as false per default for backward compat - -=== Release 0.10.1 - -- Mark additional JUnit 5 types for build-time initialization for compatibility with Native Image's `--strict-image-heap` option. - - -=== Release 0.10.0 - -- Update version of GraalVM dependency to 22.3.5 - -==== Gradle plugin - -- Update plugin to use metadata repository by default. Metadata repository <> - -==== Maven plugin - -- Update plugin to use metadata repository by default. Metadata repository <> - - -=== Release 0.9.28 - -* Fix path escaping problem for Windows users -* Fix and improve major JDK version detection. - -==== Gradle plugin - -- Remove use of deprecated `getConvention` APIs - -=== Release 0.9.27 - -* Update JUnit configuration for native testing on GraalVM for JDK 21 with `--strict-image-heap` mode. - -=== Release 0.9.26 - -* Relax GraalVM version check for dev versions -* Prepare plugins for release of _GraalVM for JDK 21_. They no longer deploy any experimental options. -* Bump Java compliance of the plugins from Java 8+ to Java 11+. -* Fix compatibility with Maven 3.9. - -==== Gradle plugin - -* Fix compatibility with Gradle 8.3 - -=== Release 0.9.25 - -* Upgrade metadata to 0.3.4 - -=== Release 0.9.24 - -* Upgrade metadata to 0.3.3 - -==== Gradle plugin - -* Add support for PGO - -=== Release 0.9.23 - -* Upgrade metadata to 0.3.2 -* Display the GraalVM logo on the generated NBT docs - -==== Gradle plugin - -- Remove use of GFileUtils -- Fix "collect reachability metadata" with config cache - -=== Release 0.9.22 - -* Upgrade metadata to 0.3.0 -* Add support for default-for attribute - -==== Gradle plugin - -- Fix lookup of metadata repository - -=== Release 0.9.21 - -* Deprecate `requiredVersion` check without replacement. - -==== Gradle plugin - -- Bump minimal version of Gradle to 7.4 -- Fix compatibility with Gradle's https://docs.gradle.org/8.0.2/userguide/configuration_cache.html#header[configuration cache] (requires Gradle 7.5+) -- Remove use of deprecated Gradle APIs -- [Behavior change] Toolchain detection is now disabled by default - -==== Maven plugin - -- Add a new `native:write-args-file` goal that can be used to write the arguments passed to `native-image` to a file - -=== Release 0.9.20 - -==== Gradle plugin - -- Fix `collectReachabilityMetadata` not being thread-safe -- Add an option to configure the maximum number of images which can be built in parallel -- Fix GraalVM version check being too strict - -==== Maven plugin - -- Add agent modes to Maven plugin - -=== Release 0.9.19 - -==== Gradle plugin - -- Fix `nativeCompile` being out-of-date whenever native runtime arguments change -- Fix GraalVM metadata repository not downloaded from project repositories by default - -==== Maven plugin - -=== Release 0.9.18 - -* Trim GraalVM version to fix Windows support -* Add tests for NativeImageUtils.escapeArg -* Do not escape quoted regexp args when using argsfile -* Upgrade to GraalVM metadata repository 0.2.5 - -=== Release 0.9.17 - -* Add a `requiredVersion` property to check the minimal GraalVM version -* Make GraalVM installation check lazy - -=== Release 0.9.16 - -* Fixed regression with a reachability-metadata repository - -=== Release 0.9.15 - -* Upgrade to GraalVM metadata repository 0.2.3. -* Ship the metadata repository as an artifact alongside the plugin -* Add ability to collect GraalVM metadata of dependencies to a custom location - -==== Gradle plugin - -* Improved diagnostics to help users figure out what GraalVM toolchain was selected - -=== Release 0.9.14 - -==== Gradle plugin -* Add ability to set environment variables to the native image builder process -* Argument files are now stored in the `build` directory (workaround for absolute path issue on Windows with older GraalVM versions) - -==== Maven plugin -* Added `native:compile` forking goal that can be started from the command line as `mvn native:compile`. -* Deprecated `build` goal in favour of `compile-no-fork` goal. This goal should now be used for attaching to the `package` phase in `pom.xml`. Attaching the `build` goal will (for now) produce a runtime warning. -* Argument files are now stored in the `target` directory (workaround for absolute path issue on Windows with older GraalVM versions). -* Default and test outputs are now much less noisy. -* When running tests in JVM mode with the native-image-agent, GraalVM's `java` executable is now always used. -* Maven plugin now shouldn't require that JVM running it must be GraalVM. - -=== Release 0.9.13 - -==== Gradle plugin -* Reverted a change in the `NativeImagePlugin` that removed publicly accessible constants. This should prevent breakage of external plugins. - -==== JUnit testing support -* Adapted the JUnit automatic metadata registration to changes in annotation handling on newer native image versions. - -=== Release 0.9.12 - -==== Gradle plugin -* Completely reworked agent support - **BREAKING CHANGE** -* The agent block is no longer tied to the target binary. -* The agent can now instrument any task that extends `JavaForkOptions`. -* Introduced the `metadataCopy` task. -* Introduced the concept of agent modes. -** Under the hood, the agent mode dictates what options are passed to the agent and how metadata produced by multiple runs get merged. -* Added `excludeConfig` configuration option that allows skipping of configuration files that are present in dependencies. -* `useArgFile` is now set to true by default only on Windows. -* Added `quickBuild` configuration option. - -==== Maven plugin -* Added support for GraalVM Reachability Metadata Repository. -* Completely reworked Maven plugin (should fix many of previous issues and inconsistencies between main and test builds). -* Added `classesDirectory`, `debug`, `fallback`, `verbose`, `sharedLibrary`, `configurationFileDirectories`, `excludeConfig`, `quickBuild`, and `jvmArgs` properties in order to match those present in the Gradle plugin. -+ -See <> for more information. -* `useArgFile` is now set to true by default only on Windows. -* Changed lookup order for `native-image` discovery -- `GRAALVM_HOME`, `JAVA_HOME`, `PATH`. - -=== Release 0.9.11 - -==== Maven plugin - -* Fix long classpath issue under Windows when running native tests -* Inherit environment variables and system properties from the surefire plugin configuration when executing tests -* Fix invocation of `native-image` when classpath contains spaces - -==== Gradle plugin - -* Add support for environment variables in native test execution -* Fix invocation of `native-image` when classpath contains spaces -* Add experimental support for the JVM reachability metadata repository - -=== Release 0.9.10 - -==== Maven plugin - -* Native testing support can now be explicitly disabled via `skipNativeTests`. - - See <> for details. -* Fixed race condition which prevented the agent files to be generated properly if tests were executed concurrently -* Documented version compatibility for the JUnit Platform and Maven Surefire plugin. - - See <> for details. -* Add support for long classpath by using an argument file when invoking `native-image` - -==== Gradle plugin - -* Fixed `nativeRun` not working properly under Windows -* Fixed race condition which prevented the agent files to be generated properly if tests were executed concurrently -* Add support for long classpath by using an argument file when invoking `native-image` - -=== Release 0.9.9 - -==== Gradle plugin - -* Fixed resource inference not working on custom binaries -* Fixed `disableToolchainDetection` not working if a GraalVM installation isn't present. Please use `graalvmNative.toolchainDetection.set(false)` instead. - -=== Release 0.9.8 - -==== Gradle plugin - -* [Breaking change] The `agent` option has been replaced with an `agent { ... }` configuration block which includes an `enabled` property. -* Toolchain support can now be disabled altogether, which can be useful when using GraalVM Enterprise Edition. - - See <> for details. -* Fixed a bug when using a _fat jar_ which assumed that all entries to be repackaged were jars. -* Agent options are now configurable. - - Note that the `experimental-class-loader-support` agent option is no longer added by default. - - See <> for details. -* Added an option to perform resource detection in classpath entries which contain a `native-image/resource-config.json` file. - -==== Maven plugin - -* The agent can now be enabled in the POM. - - See <> for details. -* Agent options are now configurable. - - Note that the `experimental-class-loader-support` agent option is no longer added by default. - - See <> for details. -* Added an option to perform resource detection in classpath entries which contain a `native-image/resource-config.json` file. - -==== JUnit Platform Native - -* Builds now correctly fail if a container-level extension or lifecycle method fails -- - for example, if an `@BeforeAll` method in a JUnit Jupiter test class throws an exception. -* Builds no longer fail when tests are aborted -- for example, via a failed assumption. -* Improved documentation for JUnit Platform and Maven Surefire support in the plugins. - -=== Release 0.9.7.1 - -==== Bugfixes - -- Fixed https://github.com/graalvm/native-build-tools/issues/144[Maven plugin configuration not applied if declared in a parent POM]. - -=== Release 0.9.7 - -Release didn't include any fixes. - -=== Release 0.9.6 - -==== Upgrade to JUnit 5.8 - -The plugins now depend on JUnit 5.8 which provides an official test listener which is used by these plugins. -As a consequence, Maven users will have to configure their builds to enable the plugin extensions: - -```xml - - org.graalvm.buildtools - native-maven-plugin - ${native.maven.plugin.version} - true - ... - -``` - -The dependency on `junit-platform-native` which used to be required pre-0.9.6 can now safely be removed. - -For Gradle users, there's no impact on the configuration, however a good consequence is that the `junit-native-platform` dependency no longer leaks into your application's classpath. - -==== Agent support for Maven plugin - -The Maven plugin now supports the GraalVM agent to generate configuration files. -Please refer to the <> for details. - -==== Disabling testing support - -The Gradle plugin now provides an option to disable testing support. -This can be useful if the test framework you are using doesn't work with this plugin or that you simply don't want to execute tests natively. - -To disable tests, use the `graalvmNative` configuration block: - -```kotlin -graalvmNative { - testSupport.set(false) -} -``` - -==== Configuring additional test images - -The Gradle plugin now supports building multiple test images, which can be used to execute tests natively for more kinds of tests: integration tests, functional tests, ... - -For more information, please refer to <> - -=== Release 0.9.5 - -This release contains, in preparation for supporting more images in the Gradle plugin: - -- The `nativeBuild` and `nativeTest` extensions are now deprecated. A top-level container for configuring native images has been introduced. Instead of: - -[source,groovy] ----- -nativeBuild { - verbose = true -} ----- - -you need to use: - -[source,groovy] ----- -graalvmNative { - binaries { - main { - verbose = true - } - } -} ----- - -and instead of: - -[source,groovy] ----- -nativeTest { - buildArgs("...") -} ----- - -you need to use: - -[source,groovy] ----- -graalvmNative { - binaries { - test { - verbose = true - } - } -} ----- - -- The `nativeBuild` task has been renamed to `nativeCompile`. -- The `nativeTestBuild` task has been renamed to `nativeTestCompile`. - -Both `nativeBuild` and `nativeTestBuild` task invocations are still supported but deprecated and will be removed in a future release. - -=== Release 0.9.4 - -This release works around a limitation for Windows users who encounter an issue with long classpath entries on CLI: the Gradle plugin will now automatically handle this problem by creating a fat jar instead of passing all entries on classpath (this behavior can be <>) if needed). -Maven users will have to <> to use shading. - -In addition to this, we're now publishing development snapshots of this plugin. For Gradle, you will need to declare this repository in your settings.gradle(.kts) file: - -[source,groovy] ----- -pluginManagement { - plugins { - id 'org.graalvm.buildtools.native' version '0.9.5-SNAPSHOT' - } - repositories { - maven { - url "https://raw.githubusercontent.com/graalvm/native-build-tools/snapshots" - } - gradlePluginPortal() - } -} ----- - -For Maven, you need to use this repository configuration: - -[source,xml] ----- - - - graalvm-native-build-tools-snapshots - GraalVM native-build-tools Snapshots - https://raw.githubusercontent.com/graalvm/native-build-tools/snapshots - - false - - - true - - - ----- - -=== Release 0.9.3 - -This release contains: - -- Fix for mainClass not being optional (Gradle plugin) -- Fix for Gradle < 7 failing to determine GraalVM toolchain -- Gradle plugin now registers proper groups -- Automatic native-image tool fetching via gu (Gradle plugin) -- FIxed issue where nativeTest would fail when tests are annotated with Timeout -- Added a sharedLibrary configuration option for Gradle plugin -- Removed broken server configuration option from Gradle plugin -- Added a documentation website with proper CI integration - -In addition to those improvements, several behind-the-scenes changes were made: - -- Introduced "Dockerless" Maven plugin functional testing -- Parallelized Gradle testing in CI -- Replaced groovy-json with jackson-databind for JSON handling -- Fixed Github Actions syntax to enable manual workflow invoking - -=== Release 0.9.2 - -This release contains: - -- Revamped Gradle plugin that is now a lot more idiomatic. -- Fixes for several issues regarding JUnit testing. -- Removal of Test Discovery mode from the Maven plugin. -- Fix for Maven creating empty test images when no tests are present. -- Added support for Kotlin tests in Gradle. +[discrete] +=== Documentation -In addition to those improvements, several behind-the-scenes changes were made in order to ensure better compatibility moving forward: +In case you are new to the Native Build Tools (eiter as an end user or a library author), read our: -- Test coverage has been greatly improved for all subprojects. -- Build tooling for this repository has been improved significantly. +- <> +- <> -Note that there has been a breaking change in the Gradle plugin - `persistConfig` configuration option was removed. -Using said option will cause existing builds to break, so users are advised to remove it from their configuration prior to upgrading. -System property `-DpersistConfig` will have no effect going forward. +For detailed documentation, please refer to the following pages of the specific build tools: -=== Release 0.9.1 +- <> +- <> -This release contains: +You can see the full changelog <>. -- Fixes for most of the known issues regarding Gradle and Maven plugins -- Massively improved automatic JUnit support as well as initial JUnit Vintage support -- Improved JavaDoc and tests for the Gradle plugin +[discrete] +=== Contributing -=== Release 0.9.0 +If you are interested in contributing or reporting an issue related to the plugins, please refer to the https://github.com/graalvm/native-build-tools[Native Build Tools repository]. +Also, be aware that all contributors must sign the https://oca.opensource.oracle.com/[Oracle Contributor Agreement] (OCA). -Initial release +[TIP] +-- +Please be aware that this repository should be used to report issues related to the Maven or Gradle plugins for GraalVM. +Please report issues which are specific to the framework itself (for example https://spring.io/[Spring Framework] or the https://micronaut.io/[Micronaut framework]) to their specific repositories. From f846fb3a6d6be8bcf3f5e63f003393ac6e41233a Mon Sep 17 00:00:00 2001 From: David Nestorovic Date: Wed, 20 Nov 2024 15:29:28 +0100 Subject: [PATCH 02/26] Redesign gh pages --- docs/src/docs/asciidoc/css/landing-page.css | 33 ------- .../docs/asciidoc/css/multi-lang-sample.css | 29 +++--- docs/src/docs/asciidoc/css/page.css | 76 +++++++++++++++ docs/src/docs/asciidoc/docinfo-footer.html | 2 +- docs/src/docs/asciidoc/docinfo-header.html | 3 + docs/src/docs/asciidoc/gradle-plugin.adoc | 6 +- .../styles/equilibrium-light.min.css | 96 ++++++++++++++++++- docs/src/docs/asciidoc/maven-plugin.adoc | 86 ++++++++++------- 8 files changed, 245 insertions(+), 86 deletions(-) delete mode 100644 docs/src/docs/asciidoc/css/landing-page.css create mode 100644 docs/src/docs/asciidoc/css/page.css create mode 100644 docs/src/docs/asciidoc/docinfo-header.html diff --git a/docs/src/docs/asciidoc/css/landing-page.css b/docs/src/docs/asciidoc/css/landing-page.css deleted file mode 100644 index 66a44fc6e..000000000 --- a/docs/src/docs/asciidoc/css/landing-page.css +++ /dev/null @@ -1,33 +0,0 @@ -body { - background: linear-gradient(rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.9)); - color: white; -} - -#header>h1:first-child { - color: white; - font-weight: 600; -} - -#header>.details { - color: white; -} - -#footer { - background: rgba(0, 0, 0, 0.2); -} - -h3 { - color: #ffc107; -} - -p { - color: white; -} - -a { - color: #00758F; -} - -.admonitionblock td.icon .icon-tip::before { - color: white; -} diff --git a/docs/src/docs/asciidoc/css/multi-lang-sample.css b/docs/src/docs/asciidoc/css/multi-lang-sample.css index df018b2b1..0bdc9b565 100644 --- a/docs/src/docs/asciidoc/css/multi-lang-sample.css +++ b/docs/src/docs/asciidoc/css/multi-lang-sample.css @@ -52,20 +52,20 @@ .multi-language-selector .language-option[data-lang='groovy'], +.multi-language-selector .language-option.selected[data-lang='groovy'], .exampleblock[data-lang=groovy] > .content .title { background-image: url(''); - background-position: 16px 80%; background-repeat: no-repeat; - background-size: 20px 12px; + background-size: 25px 14px; padding-left: 2.5em; } .multi-language-selector .language-option[data-lang='kotlin'], +.multi-language-selector .language-option.selected[data-lang='kotlin'], .exampleblock[data-lang=kotlin] > .content .title { background-image: url(''); - background-position: 17px 80%; background-repeat: no-repeat; - background-size: 11px 11px; + background-size: 12px 12px; padding-left: 2.3em; } @@ -108,8 +108,9 @@ } .multi-language-selector .language-option { - background-color: white; - border: 1px solid #f7f7f8; + color: #ffc107; + border: 1px solid gray; + background: none; border-radius: 4px 4px 0 0; cursor: pointer; display: inline-block; @@ -122,16 +123,14 @@ text-align: center; filter: grayscale(1); -webkit-filter: grayscale(1); - opacity: 0.7; } .multi-language-selector .language-option.selected { - background-color: #f7f7f8; - color: #000000; + color: #ffc107; + border: 1px solid #ffc107; font-weight: bold; filter: none; -webkit-filter: none; - opacity: 1; } .multi-language-text.hidden, @@ -149,8 +148,8 @@ .copytoclipboard { font-family: "Open Sans"; cursor: pointer; - background-color: lightgray; - color: #000000; + border: 1px solid #ffc107; + border-top: none; float: right; padding: 10px 15px; font-size: 10px; @@ -159,3 +158,9 @@ border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; } + +.copytoclipboard:hover { + background: #ffc107; + color: #00758F; + font-weight: 600; +} diff --git a/docs/src/docs/asciidoc/css/page.css b/docs/src/docs/asciidoc/css/page.css new file mode 100644 index 000000000..09ac6205e --- /dev/null +++ b/docs/src/docs/asciidoc/css/page.css @@ -0,0 +1,76 @@ +body { + background: linear-gradient(rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.85)); + color: white; +} + +#grabbit-logo { + position: absolute; + right: 0; + top: 0; + width: 150px; +} + +#toc { + background: none !important; +} + +#toc > #toctitle { + color: #ffc107; +} + +#header > h1:first-child { + color: white; + font-weight: 600; +} + +#header>.details { + color: white; +} + +#preamble>.sectionbody>[class="paragraph"]:first-of-type p { + color: white; +} + +h2, h3, h4, .title { + color: #ffc107 !important; +} + +p { + color: white; +} + +a { + color: #00a8cd; +} + +a:hover { + color: #ffc107; +} + +.listingblock >.content>pre:not(.highlight) { + color: white; + background: none; + border: 1px solid #ffc107; + border-radius: 4px; +} + +:not(pre):not([class^=L])>code { + background: #00758F; + color: white; +} + +.admonitionblock td.icon .icon-tip::before { + color: white; +} + +.admonitionblock td.icon .icon-note::before { + color: white; +} + +.admonitionblock>table td.content { + color: white; +} + +#footer { + background: rgba(0, 0, 0, 0.2); +} diff --git a/docs/src/docs/asciidoc/docinfo-footer.html b/docs/src/docs/asciidoc/docinfo-footer.html index 03dc4635a..bde51b7e7 100644 --- a/docs/src/docs/asciidoc/docinfo-footer.html +++ b/docs/src/docs/asciidoc/docinfo-footer.html @@ -1,5 +1,5 @@ - +