Skip to content

Gradle plugins for managing Liberty profile servers #devops

License

Notifications You must be signed in to change notification settings

iainduncani/ci.gradle

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ci.gradle Build Status

A Gradle plugin to support the manipulation of WebSphere Application Server Liberty Profile servers.

Build

Clone this repository and then, with a JRE on the path, execute the following command in the root directory.

gradlew build

This will download Gradle and then build the plugin liberty-gradle-plugin-1.0-SNAPSHOT.jar in to the build\libs directory. It is also possible to install the plugin in to your local Maven repository using gradlew install.

To build the plugin and run the integration tests execute the following command in the root directory.

gradlew build -PwlpInstallDir=<liberty_install_directory>
  • Liberty Profile installation is required to run the integration tests.

Usage

###1. Configuring your dependencies

1.1 Adding the ant plugin to the build script

This plugin needs the wlp-anttasks.jarfile as dependency, this file can be downloaded from the snapshot repository or the Maven central repository.

The following code snippet shows an example on how to set up your build script correctly.

buildscript {
    dependencies {
        classpath files('gradle/wlp-anttasks.jar')
    }
}

####1.2 Configuring the path to your WebSphere Application Server Liberty Profile installation You need to set up the classpath to the ws-server.jar of your WebSphere Application Server Liberty Profile installation. This JAR is located inside /bin/tools/ in your installation folder.

For example:

buildscript {
    dependencies {
        classpath files('c:/wlp/bin/tools/ws-server.jar')
    }
}

###2. Adding the binary plugin to the build script

Within your Gradle build script, you need to set up the classpath to include the Liberty Gradle plugin. You also need to define the Maven Central repository to find the plugin or its dependencies.

If you are using a snapshot version of the plugin make sure to define the Sonatype Nexus Snapshots repository in addition to the Maven Central repository.

Your build script should look like this:

buildscript {
    repositories {
        mavenCentral()
        maven {
            name = 'Sonatype Nexus Snapshots'
            url = 'https://oss.sonatype.org/content/repositories/snapshots/'
        }
    }
    dependencies {
        classpath 'net.wasdev.wlp.gradle.plugins:liberty-gradle-plugin:1.0-SNAPSHOT'
    }
}

Alternatively, you might choose to include the plugin JAR file. For example:

buildscript {
    dependencies {
        classpath files('gradle/liberty-gradle-plugin.jar')
        classpath files('gradle/wlp-anttasks.jar')
        classpath files('c:/wlp/bin/tools/ws-server.jar')
    }
}

To use the Liberty Gradle Plugin, include the following code in your build script:

apply plugin: 'liberty'

##Tasks

The plugin will have made the following tasks available to your project:

Task Description
installLiberty Installs Liberty Profile from a repository.
libertyCreate Creates a WebSphere Liberty Profile server.
libertyStart Starts the WebSphere Liberty Profile server.
libertyStop Stops the WebSphere Liberty Profile server.
libertyRun Runs a WebSphere Liberty Profile server under the Gradle process.
libertyPackage Generates a WebSphere Liberty Profile server archive.
libertyDump Dumps diagnostic information from the Liberty Profile server into an archive.
libertyJavaDump Dumps diagnostic information from the Liberty Profile server JVM.
libertyDebug Runs the Liberty Profile server in the console foreground after a debugger connects to the debug port (default: 7777).
libertyStatus Checks the WebSphere Liberty Profile server is running.
libertyPackage Generates a WebSphere Liberty Profile server archive.
deploy Deploys a supported file to the WebSphere Liberty Profile server.
undeploy Removes an application from the WebSphere Liberty Profile server.
installFeature Installs a new feature in the WebSphere Liberty Profile server.

###Extension properties The Liberty Gradle Plugin has some properties defined in the Liberty closure which will let you customize the different tasks. These properties are divided in two groups, the general properties (Which need to be set for any task excluding installLiberty task) and the specific ones. (Which only must be set when a specific task will be kicked off).

####General properties.

Attribute Description Required
wlpDir Location of the Liberty profile server installation. Yes
outputDir Value of the ${wlp_output_dir} variable. The default value is ${installDir}/usr/servers/${serverName}. No
userDir Value of the ${wlp_user_dir} variable. The default value is ${installDir}/usr/. No
serverName Name of the Liberty profile server instance. The default value is defaultServer. No

Server Properties

Attribute Description Required
clean Clean all cached information on server start up. The default value is false. Only used with the libertyStart task. No
timeout Waiting time before the server starts. The default value is 30 seconds. The unit is milliseconds. Only used with the libertyStart task. No
include A comma-delimited list of values. The valid values vary depending on the task. For the libertyPackage task the valid values are all, usr, and minify and must be declared in the packageLiberty closure. For the libertyDump task the valid values are heap, system, and thread and must be declared in the dumpLiberty closure. For the libertyJavaDump task the valid values are heap and system and must be declared in the javaDumpLiberty closure. No.
archive Location of the target archive file. Only used with the libertyPackage or libertyDump tasks on their respective closures. No
template Name of the template to use when creating a new server. Only used with the libertyCreate task. No

This example shows you how to configure these properties in your script:

apply plugin: 'liberty'

liberty {
    wlpDir = 'c:/wlp'
    serverName = 'myServer'
    userDir = 'c:/usr'
    outputDir = 'c:/usr'
    clean = true
    timeout = "10000"

    packageLiberty{
        archive = "MyServerPackage.zip"
        include = "usr"
    }
    dumpLiberty{
        archive = "C:/Dump.zip"
        include = "heap, system"
    }
    javaDumpLiberty{
        archive = "JavaDump.zip"
        include = "system"
    }
}

Of the plugin configuration, only the wlpDir property is required. The default configuration is to use a server named defaultServer under the build\wlp directory of the Gradle project.

installLiberty task

The installLiberty task is used to download and install Liberty profile server. The task can download the Liberty runtime archive from a specified location (via runtimeUrl) or automatically resolve it from the Liberty repository based on a version.

The Liberty license code must always be set in order to install the runtime. If you are installing Liberty from the Liberty repository, you can obtain the license code by reading the current license and looking for the D/N: <license code> line. Otherwise, download the runtime archive and execute java -jar wlp*runtime.jar --viewLicenseInfo command and look for the D/N: <license code> line.

####Properties

Attribute Description Required
licenseCode Liberty profile license code. See above. Yes
version Exact or wildcard version of the Liberty profile server to install. Available versions are listed in the index.yml file. Only used if runtimeUrl is not set. The default value is 8.5.+. No
runtimeUrl URL to the Liberty profile's wlp*runtime.jar. If not set, the Liberty repository will be used to find the Liberty runtime archive. No
baseDir The base installation directory. The actual installation directory of Liberty profile will be ${baseDir}/wlp. The default value is . (current working directory). No
cacheDir The directory used for caching downloaded files such as the license or .jar files. The default value is ${java.io.tmpdir}/wlp-cache. No
username Username needed for basic authentication. No
password Password needed for basic authentication. No
maxDownloadTime Maximum time in seconds the download can take. The default value is 0 (no maximum time). No

Examples

    // Install using Liberty repository
    apply plugin: 'liberty'

    liberty {

        install {
            licenseCode = "<license code>"
        }

    }

    //Install from a specific location
    apply plugin: 'liberty'

    liberty {

        install {
            licenseCode = "<license code>"
            runtimeUrl = "<url to runtime.jar>"
        }

    }

deploy task

The deploy task supports deployment of one or more applications to the Liberty Profile server.

####Properties.

Attribute Description Required
file Location of a single application to be deployed. The application type can be war, ear, rar, eba, zip, or jar. Yes, only when a single file will be deployed.
dir Location of the directory where are the applications to be deployed. Yes, only when multiples files will be deployed and file is not specified.
include Comma- or space-separated list of patterns of files that must be included. All files are included when omitted. No
exclude Comma- or space-separated list of patterns of files that must be excluded. No files are excluded when omitted. No

Deploy's properties must be set up in the deploy closure inside the liberty closure.

    // Deploys a single file
    apply plugin: 'liberty'

    liberty {
        wlpDir = 'c:/wlp'
        serverName = 'myServer'
        
        deploy {
            file = 'c:/files/app.war'
        }
    }

    //Deploy multiple files
    /*Deploy 'app.war' and 'sample.war' 
      but exclude 'test-war.war'*/
    apply plugin: 'liberty'

    liberty {
        
        wlpDir = 'c:/wlp'
        serverName = 'myServer'
        
        deploy {
            dir = 'c:/files'
            include = 'app.war, sample.war'
            exclude = 'test-war.war'
        }
    }
    
    /*Deploy multiple files using multiple closures*/
    
    apply plugin: 'liberty'

    liberty {
        
        wlpDir = 'c:/wlp'
        serverName = 'myServer'
        
        deploy {
            file = 'c:/files/app.war'
        }

        deploy {
            file = 'c:/resources/test.war'
        }
        
        deploy {
            dir = 'c:/extras'
            include = 'sample.war, demo.war'
        }
    }

The following examples shows you how to deploy a file using the WAR or the EAR gradle plugins:

    /* Deploys 'sample.war' using the WAR plugin */
    apply plugin: 'war'

    war {
        destinationDir = new File ('C:/files')
        archiveName = 'sample.war'
    }

destinationDir and archiveName are native properties of Gradle's WAR plugin. For more information see here.

    /* Deploys 'test.ear' using the EAR plugin */
    apply plugin: 'ear'

    ear {
        destinationDir = new File ('C:/files')
        archiveName = 'test.ear'
    }

destinationDir and archiveName are native properties of Gradle's EAR plugin. For more information see here.

undeploy task

The undeploy task supports undeployment of one or more applications from the Liberty Profile server.

####Properties.

Attribute Description Required
application Name of the application to be undeployed. Yes, only when a single application will be undeployed.
include Comma- or space-separated list of patterns of files that must be included. All files are included when omitted. No
exclude Comma- or space-separated list of patterns of files that must be excluded. No files are excluded when omitted. No

Undeploy's properties must be set up in the undeploy closure inside the liberty closure.

Examples

    // Undeploys a single application
    
    apply plugin: 'liberty'

    liberty {
        wlpDir = 'c:/wlp'
        serverName = 'myServer'
        
        undeploy {
            application = 'app.war'
        }
    }

    //Undeploy multiple applications
    /*Undeploy 'app.war' and 'sample.war' 
      but exclude 'test-war.war'*/
      
    apply plugin: 'liberty'

    liberty {
        
        wlpDir = 'c:/wlp'
        serverName = 'myServer'
        
        undeploy {
            include = 'app.war, sample.war'
            exclude = 'test-war.war'
        }
    }

If no property is set for the undeploy closure, but the EAR or WAR plugin is being used and their properties destinationDir and archiveName are declared, this will be the application that will be undeployed. Otherwise, all the applications available in the server at the moment of the execution will be undeployed.

installFeature task

The installFeature task installs a feature packaged as a Subsystem Archive (ESA file) to the Liberty runtime.

####Properties.

Attribute Description Required
featureName Specifies the name of the Subsystem Archive (ESA file) to be installed. The value can be a feature name, a file name or a URL. Yes
acceptLicense Accept feature license terms and conditions. The default value is false. No
whenFileExists Specifies the action to take if a file to be installed already exits. Use fail to abort the installation, ignore to continue the installation and ignore the file that exists, and replace to overwrite the existing file. No
to Specifies feature installation location. Set to usr to install as a user feature. Otherwise, set it to any configured product extension location. The default value is usr. No

The following example shows what properties must be set up to install the mongodb-2.0 feature to your server:

apply plugin: 'liberty'

liberty {
    wlpDir = "c:/wlp"

    features {
        name = ['mongodb-2.0']
        acceptLicense = true
    } 
}

Also is possible install multiple features in a single closure, for example:

/* Install 'mongodb-2.0' and 'ejbLite-3.1' features using a single closure. */
apply plugin: 'liberty'

liberty {
    wlpDir = "c:/wlp"

    features {
        name = ['mongodb-2.0', 'ejbLite-3.1']
        acceptLicense = true
    } 
}

About

Gradle plugins for managing Liberty profile servers #devops

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Groovy 100.0%