Ruby-based framework for acceptance testing
Ruby Gherkin HTML
Latest commit 4873cdc Apr 20, 2017 @romikoops romikoops updated sexy_settings
Permalink
Failed to load latest commit information.
bin
features
generators fix issue with incorrect iframe scope identifying (#222) Apr 20, 2017
lib fix issue with incorrect iframe scope identifying (#222) Apr 20, 2017
spec updated sexy_settings Apr 20, 2017
.coveralls.yml
.gitignore fixed aruba tests Jun 3, 2016
.rspec Added Travis indicator, removed debugging option from spec Aug 30, 2013
.rubocop.yml
.ruby-gemset Fixed aruba tests, finished howitzer update implementation Jan 8, 2015
.travis.yml fix issue with incorrect iframe scope identifying (#222) Apr 20, 2017
.yardopts updated changelog Sep 25, 2016
CHANGELOG.md prepare to release Mar 27, 2017
CONTRIBUTING.md Fixed settings and yard May 10, 2015
Gemfile integrate rspec-wait gem (#212) Mar 6, 2017
LICENSE fixed found issues in docs Sep 4, 2016
README.md Update README.md Mar 27, 2017
Rakefile fix issue with incorrect iframe scope identifying (#222) Apr 20, 2017
howitzer.gemspec downgrade rubocop fixes to 2.3 Mar 26, 2017

README.md

Howitzer

Ruby-based framework for acceptance testing of web applications.

The framework was built with modern patterns, techniques, and tools in automated testing in order to speed up tests development and simplify supporting.

Coverage Status

Key Benefits

  • Independent of a web application technical stack, language and architecture.
  • Fast installation and configuration of the complete testing infrastructure (takes less than 5 minutes).
  • Elegant, intuitive and powerful Ruby language underneath.
  • Possibility to choose your favorite BDD tool (Cucumber, RSpec or Turnip).
  • Integration with SauceLabs, Testingbot, BrowserStack and MailGun web services.
  • Easy tests support based on the best patterns, techniques, principles.
  • Ability to execute tests against to both browserless driver and actual browsers with no changes in your tests.

Documentation

Refer to the GETTING STARTED document to start working with Howitzer.

You can also find the Rdoc documentation on Rubygems.

Related Products

Requirements

  • Supported OS: Mac OS X, Linux, Windows
  • Ruby 2.2.2+
  • DevKit (For Windows only)
  • PhantomJS (For phantomjs and poltergeist drivers only)
  • ChromeDriver (For chrome selenium browser)
  • GeckoDriver (For firefox selenium browser)
  • SafariDriver (For safari selenium browser)
  • QT (For webkit driver only)

Setup

To install, type

gem install howitzer

Usage

Browse to a desired directory where a new project will be created.

To generate the project with Cucumber, type:

howitzer new <PROJECT NAME> --cucumber

With Rspec:

howitzer new <PROJECT NAME> --rspec

With Turnip:

howitzer new <PROJECT NAME> --turnip

Configuration

Learn and specify correct default settings in the config/default.yml file. For more details, please refer to the original sexy_settings gem.

Test Implementation Workflow

  • Prepare BDD feature with scenarios
  • Mark feature/scenarios with priority tags.
  • Implement prerequisites generation (optional):
    • implement factories
    • implement models
  • Implement appropriate pages in the web/pages folder. For details, refer to Page Object Pattern.
  • Implement emails in emails folder (optional).
  • Implement scenarios:
    • For Cucumber:
      1. Read and learn Cucumber Best Practices
      2. Implement step definitions in the features/step_definitions folder.
    • For Rspec: Use DSL provided by Capybara to create descriptive acceptance tests.
    • For Turnip: Implement step definitions in the spec/steps folder.
  • Debug features against to desired drivers.
  • Enjoy it!

Rake Tasks

Rake was originally created to handle software build processes, but the combination of convenience and flexibility that it provides has made it the standard method of job automation for Ruby projects.

You can get a list of all available tasks by typing the following command:

rake -T

Upgrading Howitzer

Before attempting to upgrade an existing project, you should be sure you have a good reason to upgrade. You need to balance several factors: the need for new features, the increasing difficulty of finding support for old code, and your available time and skills, to name a few.

From version v1.1.0 howitzer provides howitzer update command. After updating the Howitzer version in the Gemfile, run following commands:

bundle update howitzer
bundle exec howitzer update

This will help you with the creation of new files and changes of old files in an interactive session.

Don't forget to review the difference, to see if there were any unexpected changes and merge them. It is easy if your project is under revision control systems like Git.

Additional Information

Contributing

Please see CONTRIBUTING.md.

howitzer was originally designed by Roman Parashchenko and is now maintained by StrongQA team. You can find list of contributors here open source community.

License

howitzer is Copyright © 2012-2017 Roman Parashchenko and StrongQA Ltd. It is free software, and may be redistributed under the terms specified in the LICENSE file.

About StrongQA

StrongQA

howitzer is maintained and funded by StrongQA, Ltd. The names and logos for StrongQA are trademarks of StrongQA, Ltd.

We love open source software! See our other projects or hire us to consult and develop testing solutions.