Death to all bugs! Arquillian testing platform reaches first stable release

Red Hat, Inc. and the JBoss Community today announced the 1.0.0.Final release of Arquillian, its award-winning testing platform built to run on the Java Virtual Machine (JVM). Arquillian substantially reduces the effort required to write and execute Java middleware integration and functional tests. It even enables test engineers to address scenarios previously considered untestable or too expensive to test.

The Arquillian project is led by Aslak Knutsen and has received contributions from over 100 contributors and community members (between Arquillian and ShrinkWrap combined). At the JavaOne 2011 conference, Arquillian received the Duke’s Choice Award for innovation in integration testing.

The 1.0.0.Final release of Arquillian Drone, a key add-on to the platform, is included in this release. Final versions of select container adapters will be released later in the week. ShrinkWrap, a central component of Arquillian, announced its 1.0.0.Final release last week.

Mission and History

Arquillian adheres to three core principles:

  • Tests should be portable to any supported container
  • Tests should be executable from the IDE to eliminate the need for an explicit build step and to simplify debugging
  • The platform should unify the Java testing ecosystem by extending or integrating with existing test frameworks

By focusing on these principles, Arquillian makes integration and functional tests as simple to write and execute as unit tests.

Arquillian originated from the test harness developed for the CDI 1.0 (JSR-299) specification in 2009. It spun off as an independent project and has evolved into an extensible testing platform. Coming full circle, the test suite in CDI 1.1 (JSR-346), the next iteration of the CDI specification, has migrated to Arquillian. Other specifications are expected to follow. Arquillian is also used by numerous open source projects, including Hibernate, JBoss AS 7, Drools, RHQ, JClouds and Apache DeltaSpike.

Functionality

Arquillian brings test execution to the target runtime, alleviating the burden on the developer of managing the runtime from within the test or project build. To invert this control, Arquillian wraps a lifecycle around test execution that does the following:

  • Manages the lifecycle of one or more containers
  • Bundles the test case, dependent classes and resources as ShrinkWrap archives
  • Deploys the archives to the containers
  • Enriches the test case with dependency injection and other declarative services
  • Executes the tests inside (or against) the containers
  • Returns the results to the test runner for reporting

Arquillian runs with Java 1.5 and above, integrates seamlessly with familiar testing frameworks such as JUnit and TestNG and allows tests to be launched using existing IDE, Ant and Maven test plugins.

Loving quotes about Arquillian

…using Arquillian, we were able to cut the setup needed to run a plugin in-container by 90% and we were able to introduce a number of convenience annotations from which you can get a variety of data injected into your tests.”

— Lukáš Krejčí, RHQ core developer

Arquillian is a really great integration testing tool full of potential. It’s just great that the JBoss guys are aiming to provide support for almost all widely used application servers and web containers. If you are writing an application for the Java EE 6 stack, not using Arquillian is a serious mistake!”

— Bartosz Majsak, Cambridge Technology Partners

[Arquillian] reminds me of the old Cactus project back in the day, but done much, much better.”

— Laird Nelson

Newest features

Arquillian can manage more than a dozen container vendors, including JBoss AS, GlassFish and Tomcat, and supports running tests in cloud services. The container support allows developers to target a variety of technology platforms, including Java EE 5 and 6, Servlet environments, OSGi, Embedded EJB and standalone CDI.

Additional new features include:

  • Orchestration of multiple deployments across multiple containers in a single test
  • Support for multiple protocol contexts within a single deployment
  • Descriptor deployment
  • Assertions for deployment exceptions
  • A new configuration schema that supports multiple configurations per container
  • EL-like evaluation in properties and configuration overrides via Java properties
  • Explicit ordering of test methods
  • Control over when the container is started and stopped

Arquillian’s extensibility is reflected in its growing ecosystem of extensions. The most mature extension, Arquillian Drone, is included in today’s release. Drone is an abstraction over browser controllers such as Selenium and WebDriver that enables the developer to write browser-based tests without having to fuss with the typical setup and plumbing. Other extensions under active development include an Android test controller, DBUnit integration, a SeamTest replacement for testing Seam 2, BDD runners (Spock and JBehave), performance metrics, code coverage (Jacoco) and Arquillian Graphene (a type-safe Selenium API). Expect more extensions to emerge now that the platform has reached a stable release.

Availability

The Arquillian platform and extensions are available in the Maven Central and JBoss Community artifact repositories. The Arquillian libraries are typically added to the test suite of a project using a dependency management tool such as Apache Maven or Apache Ivy. Instructions for setting up Arquillian in your project and writing Arquillian tests are covered in the newly-minted Arquillian Guides.

Arquillian is released under the Apache License, v2.0, an OSI-approved open source software license.

For more information and updates about the Arquilian project, follow the Arquillian project blog and circle the Arquillian project on Google+.

arquillian.org: The Bridge of the Arquillian Project

The short version

Arquillian now has guides! If you want to know how to get started with Arquillian, head over to arquillian.org to check them out…in one of 8 languages! If you want to make them better, fork the website project and get involved.

The slightly longer version

When I thought of how to present arquillian.org, naturally images of alien spacecraft came to mind. These days, there’s a lot of activity flowing in an out of the Arquillian mothership. To manage and make sense of all that information, we were in need of a central view of everything. In other words, we needed to get to “the bridge” of the ship. From there we can monitor activity, publish the lastest information, collect and exchange ideas and decide which actions to take.

Well, we’ve made it, finally. Welcome to arquillian.org. As Bob McWhirter likes to say, “You’re soaking in it.”

The full story

We’ve been thrilled to witness the impact Arquillian has made over these last two years and the agility it’s brought to the Java ecosystem. There’s no question, the Arquillian invasion is in full force.

But even as we stood on stage at JavaOne to receive a Duke’s Choice Award for Arquillian on behalf of our awesome community, I kept thinking about how much more successful it could be. I mean, if developers have been able to figure out how to use and build on Arquillian so far, just imagine how many more developers would use it—and how much easier it would be for them—if the project actually had some decent guides to get started.

We felt your pain. We heard your voice.

That’s why we decided at JavaOne it was time to get serious about closing this gap by writing several step-by-step guides. We didn’t leave off there, though. We recognized the whole experience of discovering Arquillian for the first time (or coming back to it after a break) needs to be extremely easy and rewarding. So after we drafted the guides, we molded them into a visually appealing website with a call to action button you can’t possibly miss. We then called on our noble community members to volunteer to translate those guides into as many languages as possible. And they came through!

The long road

Ever since then, we have been trying to get these guides into your hands. It’s been a long and rather ridiculous journey. I describe it as ridiculous for contrasting reasons.

On one hand, the reason we couldn’t make it available was ridiculous. But that’s a long and boring story. On a positive note, it was ridiculous to see how much effort the community has contributed to driving this vision to make Arquillian easy to adopt and use—to a website that wasn’t even being published, no less. It certainly demonstrated a lot of spirit. That’s why we kept pressing against that first ridiculous reason to get it launched :)

The final stretch

Over the past several weeks, I’ve been working with Sarah and Aslak (with blood, sweat and tears) to get this website ready to publish. We have curated as much information as we can find—at least so far—and organized it into a website that’s going to give you a view into the Arquillian project like you’ve never seen before. Heck, even while building the website, I was stunned to finally see a list of modules, releases and changelogs in one place for the first time. And now, it’s finally out there.

A new beginning

This is just the beginning. By no means do I consider the website to be set in stone for you just to look at (though I need a few days off to sleep). Quite the opposite. arquillian.org is an open book. It’s a Creative Commons (CC BY-SA 3.0) open source project hosted on, you guessed it, github. Clone (or fork) the repository named arquillian.github.com and checkout the README. The project comes complete with an issue tracker and wiki.

It’s important to recognize that the website needs to be a part of the Arquillian project just like any other module. After all, the project is only as good as the information we put out there. I’m envisioning have contributors that join the website team much the same as they might join a module. The group will be a cross section of design, outreach, messaging, documentation and, of course, automation.

We got it spun up (nearly writing it twice) because we knew Arquillian was severely lacking in good documentation and reference material, but we want you to be as involved in it as you like.

The website reflects the quality of the software—especially in the eyes of new users—and therefore it represents all of our work. That’s why my favorite page on the site is the list of contributors ;) It’s all about you, the nobles.

What’s inside

Before I close, I want to mention some key highlights of the website. Then, I’ll leave you to explore and discover the rest :)

  • All content managed in git and hosted on Github
  • Baked with Awestruct, a static site generator
  • A data curating pipeline written in Ruby (JRuby) as Awestruct extensions
  • Pages written in Haml (with a mix of Textile)
  • Easy to read, step-by-step guides (written in Textile, changelog retrieved via git)
  • Blogs written in Textile (or Markdown)
  • Guest blogs and improvements integrated via pull requests
  • Layout and components built on Twitter Bootstrap and jQuery
  • CSS3 goodness and cross-browser support compiled by SASS
  • Designed to be responsive for mobile phones and tablets (give it a try!)
  • Module, release and commit information mined from git repositories
  • Auto-generated, in-depth blog entry plus custom notes for each release (example)
  • Detailed summary page for each module (repository, versions, dependencies, contributors, etc)
  • Contributor information backed by Github and Gravatar
  • Dynamic information retrieved via json-p (tunneled through jgfeed when necessary)
  • Upcoming talks on Arquillian syndicated from Lanyrd
  • Blogs and articles about Arquillian syndicated from Diigo
  • Under the watchful eye of Ike (as you can see in the upper-left hand corner)

If you are curious about more details, check out the Information Architecture page I drafted on the wiki about the site. Take a look at the README if you want to build the site locally.

The vision

Our vision is to automate as much as the documentation as we can possibly accomplish. It ain’t (just) because we’re lazy. It’s because we know it’s the only way to get you the most accurate, up to date information about Arquillian and to reasonably manage the growing Arquillian ecosystem. In other words, we need to be in “the bridge”. And now we have it. Just check out the module pages. What a start!

Use it. Enjoy it. Pass it on. And fork it if you want it to be better.

If words could do

I want to give a huge thanks to Sarah White, who has stuck with me through trying times to get this website looking visually stunning, organized and logical (and for just putting up with my intense focus on this project).

I also want to recognize the following translators, who have brought the guides to 8 languages in total: Markus Eisele (German), Antoine Sabot-Durand and Badr El Houari (French), Takayuki Konishi (Japanese), Hantsy Bai (Simplified Chinese), Bartosz Majsak (Polish), Jose Rodolfo Freitas (Portuguese) and Tommy Tynja (Swedish). Arquillian is forever changed because of your effort.

Finally, I want to thank all of the contributors who have embraced writing release blog entries—Vineet Reynolds, Bartosz Majsak, Karel Piwko and Lukas Fryc—and contributing guides—Karel Piwko, Paul Bakker, Lincoln Baxter and Marek Schmidt.

That’s exactly the participation I envision will make this website a key communication hub of the Arquillian project. Let’s keep the invasion strong!

Goodbye, Ajocado - Welcome, Graphene!

Goodbye, Ajocado

Wait, the Ajocado project is not leaving us!
It is just undergoing rename.
Why such a change?

Ajocado has always been a proud member of Arquillian family, however its name didn’t tell very well what’s its purpose is in the true alien world. In other words, the name didn’t fit the story.

Moreover, we have experienced many troubles explaining how Ajocado should be even pronounced.

I must admit it was unlucky choice.

Choosing the new name…

The project is like a diamond – very strong in its basis:

  • a strongly-typed, chaining API
  • efficient jQuery-based locators
  • proven to handle AJAX successfully

But on the other hand, diamonds can’t be simply manufactured.

Let’s look what more could Ajocado offer us:

  • rapid test development
  • readability
  • high-level abstractions

What can be as strong as diamond, but be much more flexible?

Welcome, Graphene

Graphene is stronger and stiffer than diamond, yet can be stretched by a quarter of its length, like rubber.

Let me introduce the Graphene – the strong and flexible UI automation tool – the old/new member of the alien crew, on the way to save the world!

What’s next?

The rename is already done, waiting in Maven repositories as Graphene 1.0.0.CR3.

And what about migration? It’s pretty straight-forward, as you can see in my previous post.

Thank you all who participated in choosing new name, renaming and migration testing (Vlasta Elias, Dan Allen, Jan Papousek, Karel Piwko)!

Project Links

Very large, active development team

According to ohloh, Arquillian has a very large, active development team. Here’s a summary of the contributor stats that ohloh curated.

Over the past twelve months, 43 developers contributed new code to Arquillian.

This is one of the largest open-source teams in the world, and is in the top 2% of all project teams on Ohloh.

For this measurement, Ohloh considered only recent changes to the code. Over the entire history of the project, 49 developers have contributed.

Thank you all for making this project so successful and fun! Arquillian has a bright future. Above all other awards and recognitions, it’s the number and diversity of contributors that’s the most significant. The smartest one amongst us is all of us, working together.

Cheers!

Arquillian Fall Tour 2011

It was quite a busy fall touring around presenting our ideas, having meetings and hooking up with our awesome community. It’s time to give the ones we missed a little insight into what’s been going on.

JavaZone – Olso – Sep 7-8

The first event this fall was near and dear to me, not only was it in my home town but also my first public presentation in Oslo. Andrew and I had great fun presenting at JavaZone, and I must say, JavaZone is probably one of the most well organized conferences I’ve ever been to. Just to give a tip to other conference organizers out there; A single baguette is not food for a warrior. And when it’s served in a 1 hour time frame to 1.500 people it tends to create queues. But not at JavaZone, where they had 7 sponsored ‘restaurants’ open all day, serving everything from sushi to traditional Norwegian elk stew. That’s the way to do it!

JavaZone started a few years back with something they call Journey-Zone: A trip for the speakers after the conference. This year the target was the MIT Fab-Lab near Tromsø in north of Norway. We headed up there on Thursday afternoon and headed back on Sunday. Hiking in the mountains, fishing in the fjords and hacking was a refreshing combination. The MIT Lab had a laser printer. Which to be honest, took most of our attention. Anything with a flat’ish surface got branded that weekend: ipads, iphones, androids, lenovos, rocks, etc. You name it, they branded it. Rumors had it they only let us play with the laser printer in hopes we wouldn’t discover their hidden Hadron Collider.

The presentation can be seen on Vimeo, Testable Enterprise Development with Arquillian.

JBoss Face2Face – Toronto Sep 12-19

Next morning I headed of to Toronto Canada for a face2face meeting with the JBoss ‘Seam’ team. ‘Seam’ team being the Seam + Richfaces + Forge + Tools + Errai developers pluss qa. We spent a week on a little island outside of Toronto in a old school building.

The general theme being: Ignore all current technical constraints. How would we want X to work? ….. then, go make it so… :)

Being that all colleagues that I interact with on a day to day basis are located in a different parts of the world, it’s always fun to come together at conferences or team meeting to meet them face 2 face. Some even for the first time.

On Thursday during the Toronto week we had arranged a JBoss BOF at the Toronto JUG. Nice group of people showed up!

During the Toronto week we released: Arquillian Core 1.0.0.CR5.

JavaOne – San Francisco – Oct 1-10

After many weeks of hectic preparation the time was upon us, JavaOne. About 11 of us rented two huge apartments to camp for the week. Having a apartment with your colleagues compared to having individual hotels rooms, made this a completely different experience. Much more fun! Making food in our own kitchen, hacking all night…

We had a brand new talk in our deck, The Extendable Enterprise Test Framework – The Arquillian SPI talk. It still needed some tweaking before presenting, so hell broke loose just before hell really broke loose. Dan and I had about 6 hours of sleep the weekend before the conference started and it didn’t really get much better during the conference. Tough week.

But, on Sunday 2. October, my birthday, JavaOne kicked of with the Duke Choice Awards. We made all aliens around the universe proud when Arquillian won the Duke Choice Awards for “Most Innovative Integration Testing Software” of 2011.

We had our new “The Extendable Exterprise TestFramwork” session on Monday and the main Arquillian event “Real Java Enterprise Testing” on Tuesday. Andrew joined in on the Tuesday session which was great fun. Probably the most exiting talk we’ve had so far. Good engaged audience. When we were about to leave the room after the talk, the security/door lady came over to thank us for a good session. She was so exited. In her own words (as I remember them: “There has been a lot of good talks in this room, but this one was the best I’ve ever seen! 3 young handsome energetic guys on stage, had the audience in your hands from the first second. I was out here trying to find more room in the back for more people.”

The audience spoke up and based on their feedback we got named JavaOne 2011 Rock Stars. Thank you!

(Last year Dan and Andrew’s became JavaOne 2010 Rock Stars for their Arquillian presentation, making it two years in a row! We’re aiming for a hat trick.)

Wednesday was the JBoss party, where Arquillian again was center stage. After sliding down to the bar at Slide you were met by a ocean of Rocking Ike’s!

One of the talks from the JBoss Booth mini theater can be found at Vimeo, High Octane Development. The rest should appear on parleys.com soon.

Goto – Århus Danmark – Oct 11-12

The plan was to come more or less directly from San Fransisco to Århus Danmark for Goto, but it became a bit more then less due to Airline mess. We came from San Fransisco and landed in Frankfurt on Monday evening. The United flight was already delayed out of San Fransisco, so we missed our connecting flight to Oslo. And the next flight was full, and so was the next one after that. We ended up having to spend the night in Frankfurt at the airport hotel. The next morning we got tickets to Oslo, but at that point there was no longer a point in going to Oslo since I needed to be in Århus that very same day. With luck I got Lufthansa to rebook my flight to Copenhagen instead.

I finally ended up in Århus at about 9 pm the 11. I call the hotel to verify my booking, for then to head directly down town to meet some of the new Red Hat Danmark people. After some time, I headed out to the hotel to find that they had overbooked and had no room for me. Back and forth, a few hours later I was in bed at a different hotel, roughly 2 am. sigh

To a small audience I pulled up the last energy I had and presented, High Octane Development: JBoss AS 7 with Arquillian. All in all considering I had a cold from San Fransisco, not to bad… :)

JUDCon – London – Oct 30-Nov 1

The 4th JUDCon was held in London, United Kingdom. We kicked of JUDCon with the Arquillian Extensions talk, being the first talk of the day, to a filled room of exited developers.

As always, this was great opportunity to meet up with the community. We ran into long time ShrinkWrap and Arquillian contributor David D’Alto for the first time. Always nice to see the face behind the cartoon character.

I had to cut JUDCon short to head over to Moscow and invade the old iron curtain.

CEE SECR – Moscow – Nov 1-4

At this point my passport was getting a bit too warn, so the airport crew in Stokholm didn’t let me pass boarding without a little discussion that ended in: Let’s give it a try! We can always fly him back.

Well, the Russian immigration lady was not impressed with my passport at all. After studying it multiple times and discussing with colleagues back and forth, I was let through after being given the evil eye and a clear message: Change passports!

Conclusion: You can get quite far with just a smile and puppy eyes. :)

This being the first time in Russia, it was quite fun riding around on the Metro in the morning trying to find the conference when you can’t tell the difference between a station name and a exit sign! But the Moscow Metro is really impressive, a massive deep underground art gallery. Even though I was lost, it was all in all quite a nice morning being that this was where I ended up:

I personally didn’t get much out of the sessions since most of them were in Russian. And as we know from previous experience, Russian is not my strong side.

I have to send out a sorry to the audience at my session which had the pleasure of experiencing my worst talk to date! Due to technical issues (HDMI only projectors? first conference ever!) I had to improvise last minute and do a demo less session on a Russian language windows 7 laptop over a flaky conference network. It could have gone smoother to say the least.

On the bright side, we did manage to release Arquillian Weblogic support during the conference. Thank you, Vineet Reynolds, for the contribution!

Devoxx – Antwerpen – Nov 15-18

Then off to the last stop of the this years tour, Devoxx! Devoxx being one of the largest European Java conference, with massive cinema session rooms and thousands of people, we were up for a fun week.

During a Hackfest we had a long chat with John Ferguson Smart, the creator of Thucydides. Thucydides is a reporting tool for ATDD based on Selenium. The outcome boils down to: He wants to focus on reporting and not so much runtime, while we focus on runtime and leave reporting to others. A match made in heaven. More to come on this later.

We had the pleasure of meeting Bartosz Majsak, another long Arquillian/ShrinkWrap support, for the first time. The combination of sleep deprivation and Belgium beer seemed to do wonders with our creativity. The later in the week, the odder the idea. It’s going to be fun implementing some of this in the upcoming months.

During the week we found the time to do the first release of: Arquillian Extension Persistence 1.0.0.Alpha1. Thank you, Bartosz Majsak, for the contribution!

You can see the recorded version of the Arquillian Extensions talk on parleys.com.

’til next time…