SlideShare a Scribd company logo
1 of 71
Faster Java EE Builds
with Gradle
RYAN CUPRAK
About
 Ryan Cuprak
 @ctjava
 rcuprak@gmail.com
 http://www.cuprak.info
 https://www.linkedin.com/in/rcuprak
Introducing Gradle
• Open source build automation system
• Apache 2.0 License
• Builds upon Apache Ant and Maven
• First released in 2007
• Uses a Groovy-based DSL (not XML)
• Uses directed acyclic graph to determine build order
• Supports multiple languages: Java, C++, C, etc.
• Rich plug-in architecture
• Convention over configuration but easily
customized/adapted
Introducing Gradle
• Build file can be versioned like dependencies.
Ever run Ant 1.9 file with Ant 1.6?
• Background daemon reduces build-time
• Supports incremental builds
• Built-in profiling support
• Build projects in parallel and some tasks*
• Built-in Ant/Maven integration
• Supported central repositories:
• Maven Central
• Jcenter
• Ivy
Build System Evolution
Ant
Maven
Gradle2004
2009
2000
Gradle versus Maven
Feature Gradle Maven
Fully configurable DAG ✅ ❌
Task Exclusion ✅ ❌
Dry Run ✅ ❌
Advanced Task Ordering ✅ ❌
Custom Distributions ✅ ❌
Repository Aware Cache ✅ ❌
Version Conflict Resolution ✅ ❌
File Based Dependencies ✅ ❌
Finalizers ✅ ❌
Custom Dependency Scopes ✅ ❌
ReplaceByRules ✅ ❌
https://gradle.org/maven-vs-gradle
Why Gradle?
Questions
1. Do you need to learn Groovy?
No (Good idea)
2. Do you need to completely refactor your code base?
No
3. Do you need additional IDE plugins?
Maybe
4. Do you need to change your build process?
Depends
5. Do you need to port your entire build system over?
No – can port over individual modules
6. Can you embed custom Ant logic?
Yes
Questions…
7. Must all dependencies originate from a repository?
No
8. Can artifacts be pushed to a repository?
Yes
9. Can Jenkins initiate Gradle builds?
Yes
Why Gradle for Java EE?
Java EE projects are:
 Large
 Complex
 Contain many dependencies
 Ant lacks dependency management
Large Ant files are a nightmare to debug
Maven isn’t flexible
 Custom plugins aren’t the solution
 Evolving slowly
Installation
 Installation similar to Ant/Maven
 Download and install from gradle.org
 Set environment variables:
 GRADLE_HOME
 PATH (to GRADLE_HOME/bin)
 gradle = ant = mvn
Key Gradle Files
Build file build.gradle
Configuration settings settings.gradle
Local settings ~/.gradle/gradle.properties
Local repository (project)/.gradle
build.gradle = pom.xml = build.xml
Gradle Daemon
Gradle daemon is enabled by default
(Disable for continuous build environments!)
Displaying status
gradle –status
Stopping daemon:
gradle –stop
Disabling daemon:
Add org.gradle.daemon=false to ~/.gradle
Project Creation
To start a new project:
 gradle init – creates a new project
 Uses pom.xml if present.
 Imports multi-model projects
 Optionally specify –type <type>
 java-library
 scala-library
 groovy-library
 basic (default) – no src directories created.
 Central repository defaults to jcenter()
https://bintray.com/bintray/jcenter
Project Creation…
 gradle init --type java-library
Default Project Layout
src
main
resources
test
java
resources
build.gradle
settings.gradle
java
project
Initial Gradle File
Command line – listing tasks
gradle –q tasks
------------------------------------------------------------
All tasks runnable from root project
------------------------------------------------------------
Build tasks
-----------
assemble - Assembles the outputs of this project.
build - Assembles and tests this project.
buildDependents - Assembles and tests this project and all
projects that depend on it.
buildNeeded - Assembles and tests this project and all projects
it depends on.
classes - Assembles classes 'main'.
clean - Deletes the build directory.
jar - Assembles a jar archive containing the main classes.
testClasses - Assembles classes 'test'.
Tasks Continued…
Build Setup tasks
-----------------
init - Initializes a new Gradle build. [incubating]
wrapper - Generates Gradle wrapper files. [incubating]
Documentation tasks
-------------------
javadoc - Generates Javadoc API documentation for the
main source code.
Tasks Continue…
Help tasks
----------
components - Displays the components produced by root
project 'scratch'. [incubating]
dependencies - Displays all dependencies declared in root
project 'scratch'.
dependencyInsight - Displays the insight into a specific
dependency in root project 'scratch'.
help - Displays a help message.
model - Displays the configuration model of root project
'scratch'. [incubating]
projects - Displays the sub-projects of root project 'scratch'.
properties - Displays the properties of root project 'scratch'.
tasks - Displays the tasks runnable from root project 'scratch'.
Verification tasks
------------------
check - Runs all checks.
test - Runs the unit tests.
Sample Output
gradle build
src
build
scratch-1.0-SNAPSHOT.jar
libs
project
Output
Projects versus Tasks
Project 1 Project 2
Project 3
Task 1
Task 3
Task 2
Depends on
Task 1
Task 2
Depends on
Task 1
Task 3
Task 2
Depends on
Task 3
Depends on
Understanding build.gradle
org.gradle.api.Project
apply(options: Map<String,?>)
buildscript(config: Closure)
dependencies(config: Closure)
configurations(config: Closure)
getDependencies()
getConfigurations()
getAnt()
getName()
getDescription()
getGroup()
getPath()
getVersion()
getLogger()
setDescription(description: String)
setVersion(version: Object)
file(path: Object)
task(args: Map<String,?>,name: String)
Project is an implicit object.
Project.apply plugin: ‘java
Understanding Gradle Tasks
org.gradle.api.Task
dependsOn(tasks: Object…)
doFirst(action: Closure)
doLast(action: Closure)
getActions()
getInputs()
getOutputs()
getAnt()
getDescription()
getEnabled()
getGroup()
setDescription(description: String)
setEnabled(enabled: boolean)
setGroup(group: String)
Tasks are built on the Task object.
Defining Tasks
Task Dependencies
Grouping Tasks
Grouping Tasks
Custom Group
Plugins
Plugin ID Automatically
Applies
Works With Description
java java-base Java compilation/testing
application java,distribution
ear java Java EE Support
maven java,war Maven publishing
war java Assembles WAR files
java-library-
distribution
java, distribution Support for tar/zip
distributions for Java
library.
idea java Generates IDEA files
eclipse java,groovy,
scala
Generates Eclipse files
Standard: https://docs.gradle.org/current/userguide/standard_plugins.html
Third party: https://plugins.gradle.org
Multi-Module Projects
Multi-Module Projects
admin-web
model
myApp
web
mobile-app
build.gradle
gradle.properties
admin-web
model
myApp
web
mobile-app
build.gradle
gradle.properties
master
Hierarchical Layout Flat Layout
Hierarchical Layout: Example Project
ctjava
build.gradle
settings.gradle
ctcore
build.gradle
settings.gradle
ctweb
build.gradle
settings.gradle
migrate
build.gradle
settings.gradle
Hierarchical Layout: Top Level
build.gradle gradle.settings
ctjava
Hierarchical Layout: Second Level
 gradle.settings for ctcore/migrate/ctweb:
rootProject.name = 'ctjava’
 migrate/ctweb dependencies on ctcore
compile project (':ctcore’)
IDE Support
IDE Support
IDE Separate Plugin Java EE Support
IDEA (free) No Yes
IDEA (paid) No Yes
NetBeans Yes Depends
Eclipse Yes Yes
Eclipse Gradle Support
 http://download.eclipse.org/buildship/updates/e46/r
eleases/1.0
NetBeans Gradle Support
Multi-project Java EE projects not recognized.
IntelliJ Support
Legacy Project
NetBeans EE Project to Gradle
File System Project Representation
NetBeans EE Project to Gradle
Java Source
directories
WAR Plugin
Local JARs
NetBeans EE Project to Gradle
Web resource
directory
Java EE
Dependencies
Local JAR
Continued…
WAR Plugin Configuration
Configuration Description
from Adds a file-set to the root of the archive
webInf Adds a file-set to the WEB-INF dir.
classpath Adds a file-set to the WEB-INF/lib dir
webAppDirName The name of the web application source directory, relative
to the project directory.
webXml Copies a file to WEB-INF/web.xml
Recipes
JavaScript Minification
Minification Output
Google Minifier
JavaScript Minification…
 Extend JavaExec Task to invoke Minifier
JavaScript Minification…
gradle -PjsOptimize=true build
Node/Webpack Integration
Node Gradle Plugin
https://github.com/srs/gradle-node-plugin
Supports: NodeJS, Yarn, Grunt, Gulp
Generating JPA Meta-Model
Create custom plugin to run Java Annotation Processor:
implementation-class=JavaAptPlugin
Custom Annotation Processor
Custom annotation processor
Custom Annotation Processor
Custom annotation processor
Custom Annotation Processor:
Build Plugin
Exclude everything
but JPA entities
Custom annotation processor
EAR Projects
Project Output
Contents of EAR
EAR Project
EAR plugin
Provided Scope – Non-WAR Projects
• providedCompile is a configuration on WAR plugin.
• Non-WAR projects must add a custom scope.
jaxb Code Generation
POJOxsd
Generating JAX-WS Client
 Generate JAX-WS client for WSDL using wsimport
 Plugin:
 https://plugins.gradle.org/plugin/me.seeber.wsimport
 Generated source code:
 build/generated-src/wsimport
Generating JAX-WS Client
https://plugins.gradle.org/plugin/me.seeber.wsimport
Generating JAX-WS Client
Generated Source Code
Docker
 Build Docker images from project output:
 Transmode/gradle-docker - http://tinyurl.com/k7o7nab
 Build/publish docker files from build script – not Dockerfile
 bmuschko/gradle-docker-plugin -
http://tinyurl.com/hg4q6jr
 docker-remote-api – interacts with Docker via remote API
 docker-java-application – creates/pushes docker images for java
applications
 Run Docker containers during build
 palantir/gradle-docker - http://tinyurl.com/hpw853h
 docker – building and pushing docker images
 docker-compose - populating placeholders in a docker-compose
template
 docker-run – starting/stopping/status on named images
Building Docker Images
Simple Docker Example – Run
Container
Available Tasks:
• dockerRun
• dockerStop
• dockerRunStatus
• dockerRemoveContainer
Docker & Testing
 Launch PostgreSQL Docker container before unit tests
execute
 Test cleanup:
 Leave container running if any tests fail
 Destroy container if tests succeed
Docker & Testing
Docker Database Testing
Parameter Substitution: persistence.xml
Parameter Substitution: build.gradle
Testing with Arquillian/Selenium
Misc
 View Dependencies:
gradle -q ctweb:dependencies
 Build GUI:
gradle –gui
 Profiling:
gradle –profile
 Dryrun
gradle –m build
Reasons to Convert
 Incremental compilation
 Better dependency management/control
 Customizable without needing plugins
 Supports multiple languages/platforms
 Build system can be versioned
Q&A

More Related Content

What's hot

Project Presentation on Advance Java
Project Presentation on Advance JavaProject Presentation on Advance Java
Project Presentation on Advance Java
Vikas Goyal
 

What's hot (20)

Faster java ee builds with gradle [con4921]
Faster java ee builds with gradle [con4921]Faster java ee builds with gradle [con4921]
Faster java ee builds with gradle [con4921]
 
Getting Started with Java EE 7
Getting Started with Java EE 7Getting Started with Java EE 7
Getting Started with Java EE 7
 
Why Play Framework is fast
Why Play Framework is fastWhy Play Framework is fast
Why Play Framework is fast
 
Scala play-framework
Scala play-frameworkScala play-framework
Scala play-framework
 
Spring Framework - Core
Spring Framework - CoreSpring Framework - Core
Spring Framework - Core
 
Next stop: Spring 4
Next stop: Spring 4Next stop: Spring 4
Next stop: Spring 4
 
Don't Wait! Develop Responsive Applications with Java EE7 Instead
Don't Wait! Develop Responsive Applications with Java EE7 InsteadDon't Wait! Develop Responsive Applications with Java EE7 Instead
Don't Wait! Develop Responsive Applications with Java EE7 Instead
 
Apache DeltaSpike the CDI toolbox
Apache DeltaSpike the CDI toolboxApache DeltaSpike the CDI toolbox
Apache DeltaSpike the CDI toolbox
 
Angular beans
Angular beansAngular beans
Angular beans
 
PUC SE Day 2019 - SpringBoot
PUC SE Day 2019 - SpringBootPUC SE Day 2019 - SpringBoot
PUC SE Day 2019 - SpringBoot
 
Spring 3.1 to 3.2 in a Nutshell - Spring I/O 2012
Spring 3.1 to 3.2 in a Nutshell - Spring I/O 2012Spring 3.1 to 3.2 in a Nutshell - Spring I/O 2012
Spring 3.1 to 3.2 in a Nutshell - Spring I/O 2012
 
Introduction to Spring Framework
Introduction to Spring FrameworkIntroduction to Spring Framework
Introduction to Spring Framework
 
Advance java Online Training in Hyderabad
Advance java Online Training in HyderabadAdvance java Online Training in Hyderabad
Advance java Online Training in Hyderabad
 
Project Presentation on Advance Java
Project Presentation on Advance JavaProject Presentation on Advance Java
Project Presentation on Advance Java
 
Play vs Grails Smackdown - Devoxx France 2013
Play vs Grails Smackdown - Devoxx France 2013Play vs Grails Smackdown - Devoxx France 2013
Play vs Grails Smackdown - Devoxx France 2013
 
Deployment of WebObjects applications on FreeBSD
Deployment of WebObjects applications on FreeBSDDeployment of WebObjects applications on FreeBSD
Deployment of WebObjects applications on FreeBSD
 
Play Framework and Activator
Play Framework and ActivatorPlay Framework and Activator
Play Framework and Activator
 
20151010 my sq-landjavav2a
20151010 my sq-landjavav2a20151010 my sq-landjavav2a
20151010 my sq-landjavav2a
 
Microservices - java ee vs spring boot and spring cloud
Microservices - java ee vs spring boot and spring cloudMicroservices - java ee vs spring boot and spring cloud
Microservices - java ee vs spring boot and spring cloud
 
Short intro to scala and the play framework
Short intro to scala and the play frameworkShort intro to scala and the play framework
Short intro to scala and the play framework
 

Viewers also liked

Viewers also liked (20)

Containerless in the Cloud with AWS Lambda
Containerless in the Cloud with AWS LambdaContainerless in the Cloud with AWS Lambda
Containerless in the Cloud with AWS Lambda
 
Top 50 java ee 7 best practices [con5669]
Top 50 java ee 7 best practices [con5669]Top 50 java ee 7 best practices [con5669]
Top 50 java ee 7 best practices [con5669]
 
Поисковый отряд им.генерала кузнецова
Поисковый отряд им.генерала кузнецоваПоисковый отряд им.генерала кузнецова
Поисковый отряд им.генерала кузнецова
 
Synergy Digital
Synergy Digital Synergy Digital
Synergy Digital
 
Docker and java, at Montréal JUG
Docker and java, at Montréal JUGDocker and java, at Montréal JUG
Docker and java, at Montréal JUG
 
Mi historia
Mi historiaMi historia
Mi historia
 
Знакомство с маркетингом от Станислава Маслихина
Знакомство с маркетингом от Станислава МаслихинаЗнакомство с маркетингом от Станислава Маслихина
Знакомство с маркетингом от Станислава Маслихина
 
O rastreio dos transgénicos
O rastreio dos transgénicosO rastreio dos transgénicos
O rastreio dos transgénicos
 
Practica de aula innovadora
Practica de aula innovadoraPractica de aula innovadora
Practica de aula innovadora
 
Donmatías avanza 08 de marzo de 2017
Donmatías avanza 08 de marzo de 2017Donmatías avanza 08 de marzo de 2017
Donmatías avanza 08 de marzo de 2017
 
Fibra óptica
Fibra ópticaFibra óptica
Fibra óptica
 
Competencias y habilidades del s xxi
Competencias y habilidades del s xxiCompetencias y habilidades del s xxi
Competencias y habilidades del s xxi
 
Eğitim ve Koçlukta Oyun / Oyunlaştırma
Eğitim ve Koçlukta Oyun / OyunlaştırmaEğitim ve Koçlukta Oyun / Oyunlaştırma
Eğitim ve Koçlukta Oyun / Oyunlaştırma
 
A Collaborative Approach to Teach Software Architecture - SIGCSE 2017
A Collaborative Approach to Teach Software Architecture - SIGCSE 2017A Collaborative Approach to Teach Software Architecture - SIGCSE 2017
A Collaborative Approach to Teach Software Architecture - SIGCSE 2017
 
ΠΕΡΙΛΗΨΗ ΤΟΥ ΒΙΒΛΙΟΥ :Η ΚΑΛΥΒΑ ΤΟΥ ΜΠΑΡΜΠΑ-ΘΩΜΑ ΑΠΟ ΤΗΝ ΑΝΔΡΙΑΝΑ,ΤΑΞΗ Α΄
ΠΕΡΙΛΗΨΗ ΤΟΥ ΒΙΒΛΙΟΥ :Η ΚΑΛΥΒΑ ΤΟΥ ΜΠΑΡΜΠΑ-ΘΩΜΑ ΑΠΟ ΤΗΝ ΑΝΔΡΙΑΝΑ,ΤΑΞΗ Α΄ΠΕΡΙΛΗΨΗ ΤΟΥ ΒΙΒΛΙΟΥ :Η ΚΑΛΥΒΑ ΤΟΥ ΜΠΑΡΜΠΑ-ΘΩΜΑ ΑΠΟ ΤΗΝ ΑΝΔΡΙΑΝΑ,ΤΑΞΗ Α΄
ΠΕΡΙΛΗΨΗ ΤΟΥ ΒΙΒΛΙΟΥ :Η ΚΑΛΥΒΑ ΤΟΥ ΜΠΑΡΜΠΑ-ΘΩΜΑ ΑΠΟ ΤΗΝ ΑΝΔΡΙΑΝΑ,ΤΑΞΗ Α΄
 
Showcase Your Brand in Front of Thousands of Top Digital Marketers
Showcase Your Brand in Front of Thousands of Top Digital MarketersShowcase Your Brand in Front of Thousands of Top Digital Marketers
Showcase Your Brand in Front of Thousands of Top Digital Marketers
 
Core java
Core javaCore java
Core java
 
Mapa mental
Mapa mentalMapa mental
Mapa mental
 
Reacciones orgánicas y ácido base (prof. edgar del carpio)
Reacciones orgánicas y ácido base (prof. edgar del carpio)Reacciones orgánicas y ácido base (prof. edgar del carpio)
Reacciones orgánicas y ácido base (prof. edgar del carpio)
 
04 Strategies to Develop a Better Management Approach
04 Strategies to Develop a Better Management Approach04 Strategies to Develop a Better Management Approach
04 Strategies to Develop a Better Management Approach
 

Similar to Faster Java EE Builds with Gradle

Gradle - time for a new build
Gradle - time for a new buildGradle - time for a new build
Gradle - time for a new build
Igor Khotin
 
How to start using Scala
How to start using ScalaHow to start using Scala
How to start using Scala
Ngoc Dao
 

Similar to Faster Java EE Builds with Gradle (20)

Gradle - Build system evolved
Gradle - Build system evolvedGradle - Build system evolved
Gradle - Build system evolved
 
Gradle - time for a new build
Gradle - time for a new buildGradle - time for a new build
Gradle - time for a new build
 
OpenCms Days 2012 - Developing OpenCms with Gradle
OpenCms Days 2012 - Developing OpenCms with GradleOpenCms Days 2012 - Developing OpenCms with Gradle
OpenCms Days 2012 - Developing OpenCms with Gradle
 
Gradle: The Build System you have been waiting for!
Gradle: The Build System you have been waiting for!Gradle: The Build System you have been waiting for!
Gradle: The Build System you have been waiting for!
 
Gradle - Build System
Gradle - Build SystemGradle - Build System
Gradle - Build System
 
Gradle notes
Gradle notesGradle notes
Gradle notes
 
Introduction to gradle
Introduction to gradleIntroduction to gradle
Introduction to gradle
 
Gradle: The Build system you have been waiting for
Gradle: The Build system you have been waiting forGradle: The Build system you have been waiting for
Gradle: The Build system you have been waiting for
 
An introduction to maven gradle and sbt
An introduction to maven gradle and sbtAn introduction to maven gradle and sbt
An introduction to maven gradle and sbt
 
GradleFX
GradleFXGradleFX
GradleFX
 
Javaone - Gradle: Harder, Better, Stronger, Faster
Javaone - Gradle: Harder, Better, Stronger, Faster Javaone - Gradle: Harder, Better, Stronger, Faster
Javaone - Gradle: Harder, Better, Stronger, Faster
 
Make Your Build Great Again (DroidConSF 2017)
Make Your Build Great Again (DroidConSF 2017)Make Your Build Great Again (DroidConSF 2017)
Make Your Build Great Again (DroidConSF 2017)
 
Android gradle-build-system-overview
Android gradle-build-system-overviewAndroid gradle-build-system-overview
Android gradle-build-system-overview
 
Android presentation - Gradle ++
Android presentation - Gradle ++Android presentation - Gradle ++
Android presentation - Gradle ++
 
How to start using Scala
How to start using ScalaHow to start using Scala
How to start using Scala
 
What's new in Gradle 4.0
What's new in Gradle 4.0What's new in Gradle 4.0
What's new in Gradle 4.0
 
Gradle - the Enterprise Automation Tool
Gradle  - the Enterprise Automation ToolGradle  - the Enterprise Automation Tool
Gradle - the Enterprise Automation Tool
 
Gradle como alternativa a maven
Gradle como alternativa a mavenGradle como alternativa a maven
Gradle como alternativa a maven
 
Gradle 2.Write once, builde everywhere
Gradle 2.Write once, builde everywhereGradle 2.Write once, builde everywhere
Gradle 2.Write once, builde everywhere
 
Serverless Container with Source2Image
Serverless Container with Source2ImageServerless Container with Source2Image
Serverless Container with Source2Image
 

More from Ryan Cuprak

Hybrid Mobile Development with Apache Cordova and
Hybrid Mobile Development with Apache Cordova and Hybrid Mobile Development with Apache Cordova and
Hybrid Mobile Development with Apache Cordova and
Ryan Cuprak
 

More from Ryan Cuprak (13)

Jakarta EE Test Strategies (2022)
Jakarta EE Test Strategies (2022)Jakarta EE Test Strategies (2022)
Jakarta EE Test Strategies (2022)
 
DIY Home Weather Station (Devoxx Poland 2023)
DIY Home Weather Station (Devoxx Poland 2023)DIY Home Weather Station (Devoxx Poland 2023)
DIY Home Weather Station (Devoxx Poland 2023)
 
Polygot Java EE on the GraalVM
Polygot Java EE on the GraalVMPolygot Java EE on the GraalVM
Polygot Java EE on the GraalVM
 
Exploring Java Heap Dumps (Oracle Code One 2018)
Exploring Java Heap Dumps (Oracle Code One 2018)Exploring Java Heap Dumps (Oracle Code One 2018)
Exploring Java Heap Dumps (Oracle Code One 2018)
 
Java script nirvana in netbeans [con5679]
Java script nirvana in netbeans [con5679]Java script nirvana in netbeans [con5679]
Java script nirvana in netbeans [con5679]
 
Jms deep dive [con4864]
Jms deep dive [con4864]Jms deep dive [con4864]
Jms deep dive [con4864]
 
Developing in the Cloud
Developing in the CloudDeveloping in the Cloud
Developing in the Cloud
 
Combining R With Java For Data Analysis (Devoxx UK 2015 Session)
Combining R With Java For Data Analysis (Devoxx UK 2015 Session)Combining R With Java For Data Analysis (Devoxx UK 2015 Session)
Combining R With Java For Data Analysis (Devoxx UK 2015 Session)
 
Hybrid Mobile Development with Apache Cordova and
Hybrid Mobile Development with Apache Cordova and Hybrid Mobile Development with Apache Cordova and
Hybrid Mobile Development with Apache Cordova and
 
JavaFX Versus HTML5 - JavaOne 2014
JavaFX Versus HTML5 - JavaOne 2014JavaFX Versus HTML5 - JavaOne 2014
JavaFX Versus HTML5 - JavaOne 2014
 
50 EJB 3 Best Practices in 50 Minutes - JavaOne 2014
50 EJB 3 Best Practices in 50 Minutes - JavaOne 201450 EJB 3 Best Practices in 50 Minutes - JavaOne 2014
50 EJB 3 Best Practices in 50 Minutes - JavaOne 2014
 
Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)
Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)
Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)
 
JavaOne 2013: Organizing Your Local Community
JavaOne 2013: Organizing Your Local CommunityJavaOne 2013: Organizing Your Local Community
JavaOne 2013: Organizing Your Local Community
 

Recently uploaded

Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Medical / Health Care (+971588192166) Mifepristone and Misoprostol tablets 200mg
 
The title is not connected to what is inside
The title is not connected to what is insideThe title is not connected to what is inside
The title is not connected to what is inside
shinachiaurasa2
 
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
masabamasaba
 
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
masabamasaba
 
%+27788225528 love spells in Atlanta Psychic Readings, Attraction spells,Brin...
%+27788225528 love spells in Atlanta Psychic Readings, Attraction spells,Brin...%+27788225528 love spells in Atlanta Psychic Readings, Attraction spells,Brin...
%+27788225528 love spells in Atlanta Psychic Readings, Attraction spells,Brin...
masabamasaba
 
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
masabamasaba
 

Recently uploaded (20)

Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
 
The title is not connected to what is inside
The title is not connected to what is insideThe title is not connected to what is inside
The title is not connected to what is inside
 
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
%+27788225528 love spells in new york Psychic Readings, Attraction spells,Bri...
 
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
 
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...
WSO2CON 2024 - Cloud Native Middleware: Domain-Driven Design, Cell-Based Arch...
 
%in Midrand+277-882-255-28 abortion pills for sale in midrand
%in Midrand+277-882-255-28 abortion pills for sale in midrand%in Midrand+277-882-255-28 abortion pills for sale in midrand
%in Midrand+277-882-255-28 abortion pills for sale in midrand
 
%in Soweto+277-882-255-28 abortion pills for sale in soweto
%in Soweto+277-882-255-28 abortion pills for sale in soweto%in Soweto+277-882-255-28 abortion pills for sale in soweto
%in Soweto+277-882-255-28 abortion pills for sale in soweto
 
WSO2CON2024 - It's time to go Platformless
WSO2CON2024 - It's time to go PlatformlessWSO2CON2024 - It's time to go Platformless
WSO2CON2024 - It's time to go Platformless
 
WSO2Con2024 - WSO2's IAM Vision: Identity-Led Digital Transformation
WSO2Con2024 - WSO2's IAM Vision: Identity-Led Digital TransformationWSO2Con2024 - WSO2's IAM Vision: Identity-Led Digital Transformation
WSO2Con2024 - WSO2's IAM Vision: Identity-Led Digital Transformation
 
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
 
WSO2CON 2024 - WSO2's Digital Transformation Journey with Choreo: A Platforml...
WSO2CON 2024 - WSO2's Digital Transformation Journey with Choreo: A Platforml...WSO2CON 2024 - WSO2's Digital Transformation Journey with Choreo: A Platforml...
WSO2CON 2024 - WSO2's Digital Transformation Journey with Choreo: A Platforml...
 
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...
WSO2CON 2024 - Building the API First Enterprise – Running an API Program, fr...
 
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
 
%+27788225528 love spells in Atlanta Psychic Readings, Attraction spells,Brin...
%+27788225528 love spells in Atlanta Psychic Readings, Attraction spells,Brin...%+27788225528 love spells in Atlanta Psychic Readings, Attraction spells,Brin...
%+27788225528 love spells in Atlanta Psychic Readings, Attraction spells,Brin...
 
%in kempton park+277-882-255-28 abortion pills for sale in kempton park
%in kempton park+277-882-255-28 abortion pills for sale in kempton park %in kempton park+277-882-255-28 abortion pills for sale in kempton park
%in kempton park+277-882-255-28 abortion pills for sale in kempton park
 
Architecture decision records - How not to get lost in the past
Architecture decision records - How not to get lost in the pastArchitecture decision records - How not to get lost in the past
Architecture decision records - How not to get lost in the past
 
Payment Gateway Testing Simplified_ A Step-by-Step Guide for Beginners.pdf
Payment Gateway Testing Simplified_ A Step-by-Step Guide for Beginners.pdfPayment Gateway Testing Simplified_ A Step-by-Step Guide for Beginners.pdf
Payment Gateway Testing Simplified_ A Step-by-Step Guide for Beginners.pdf
 
%in Harare+277-882-255-28 abortion pills for sale in Harare
%in Harare+277-882-255-28 abortion pills for sale in Harare%in Harare+277-882-255-28 abortion pills for sale in Harare
%in Harare+277-882-255-28 abortion pills for sale in Harare
 
VTU technical seminar 8Th Sem on Scikit-learn
VTU technical seminar 8Th Sem on Scikit-learnVTU technical seminar 8Th Sem on Scikit-learn
VTU technical seminar 8Th Sem on Scikit-learn
 
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
 

Faster Java EE Builds with Gradle