Atomist software delivery machine (SDM) extension pack providing automated creation, building, and delivery of Spring and Spring Boot applications.
Also includes Java, Kotlin, Maven and Gradle support and Java formatting support
using spring-format
.
See the Atomist documentation for more information on what SDMs are and what they can do for you using the Atomist API for software.
This pack adds Spring Boot, Java and Kotlin functionality to an Atomist SDM. It includes:
- Building blocks for Atomist generators based on Spring Boot seed projects: core code transforms and parameter definitions
- Basic Java refactoring support
- Commands to add and configure Spring Boot starters, based on the Spring Guides
- Useful out of the box code transforms such as
try to upgrade spring boot
- Code inspections to help ensure Spring Boot best practice, such as removing unnecessary annotations.
- PushTests supporting Spring, Spring Boot, Java, Kotlin, Maven and Gradle.
- Local deployment support for Spring Boot projects, using Maven or Gradle.
This pack provides a basis on which to build further Spring Boot and Java functionality, such as custom support for additional Spring Boot starters. Community contributions welcome!
This functionality is based on the following low level building blocks:
- Code transform primitives for Java, including
- Add import to a given class
- Add annotation to a given class
- Move package
- Rename class
- Add Maven dependency
- Code transform primitives for Spring, including
- Add Spring Boot starter
- Add annotation to Spring Boot class
- Structural inference
- Infer Spring Boot package
- XML support
- Support for parsing and editing XML using Atomist path expressions
- Properties file support
PropertiesFile
type enabling querying and adding properties
Java and Kotlin support depends on the support for Java and Kotlin grammars in the @atomist/antlr-ts project.
Install the dependency in your SDM project.
$ npm install @atomist/sdm-pack-spring
Then use its exported method to add the functionality to your SDM in your machine definition.
import {
SoftwareDeliveryMachine,
SoftwareDeliveryMachineConfiguration,
} from "@atomist/sdm";
import {
createSoftwareDeliveryMachine,
} from "@atomist/sdm-core";
import { SpringSupport } from "@atomist/sdm-pack-spring";
export function machine(configuration: SoftwareDeliveryMachineConfiguration): SoftwareDeliveryMachine {
const sdm = createSoftwareDeliveryMachine({
name: "My Software Delivery Machine",
configuration,
});
sdm.addExtensionPacks(SpringSupport);
return sdm;
};
General support questions should be discussed in the #support
channel in the Atomist community Slack workspace.
If you find a problem, please create an issue.
You will need to install Node.js to build and test this project.
Install dependencies.
$ npm install
Use the build
package script to compile, test, lint, and build the
documentation.
$ npm run build
To use the spring-format
support, you need to clone the Atomist spring-format
wrapper project from https://github.com/atomist/spring-format and follow the instructions
to create an executable JAR file and specify its path in the sdm.spring.formatJar
configuration
property or the FORMAT_JAR
environment variable.
Releases are handled via the Atomist SDM. Just press the 'Approve' button in the Atomist dashboard or Slack.
- While Kotlin generators are fully supported, not all code transform commands support Kotlin. This project should fully support Kotlin.
- Support further Spring Boot starters, including realistic configuration
Community contributions welcome!
This pack is intended as an example of an Atomist extension pack targeted at a developer-facing technology.
To achieve comparable functionality for any other framework, the following is a rough guide:
- Add support for the underlying language. Java, Kotlin, TypeScript and JavaScript are already supported in Atomist modules; to integrate other languages, look to Atomist's ANTLR integration.
- Add support for the relevant configuration formats. XML and properties files are supported in this repository. (Basic functionality can be achieved using regular expressions and microgrammars.)
- Implement language-oriented primitives such as 'add import' using language support.
- Implement support for the relevant build system, such as Maven or Gradle. If possible, this should extend beyond build to deployment.
- Add useful code transforms and expose them as commands. For example,
setSpringBootVersion
in this repository. - Add useful code inspections, for example to flag common errors.
Created by Atomist. Need Help? Join our Slack workspace.
brew tap starkandwayne/cf
brew install riff