Extends Crystal Spec for testing web applications
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
spec
src [Api] Adds Page method to System Test API Jun 25, 2018
.gitignore
.gitmessage
.travis.yml
LICENSE
README.md
shard.yml

README.md

Build Status

System Test Framework

A Crystal library to perform system and controller tests for Web Applications.

System Testing is a level of the software testing where a complete and integrated software is tested. The purpose of a system test is to evaluate the system’s compliance with the specified requirements.

When is it performed?

System Testing is performed after Integration Testing and before Acceptance Testing.

Installation

Add this to your application's shard.yml:

dependencies:
  garnet_spec:
    github: amberframework/garnet-spec

Installing java

MacOS: brew cask install java then java --version to verify installation.

Usage

Before running your tests ensure you have installed the chromedriver in your system path

For MacOS you can install the driver using Homebrew with the following command:

brew install chromedriver

This will install the chrome driver on the system path /usr/local/bin/chromedriver

If you're running in a different OS such a Linux you can specify the chromedriver path as such

# spec/spec_helper.cr
require "amber"
require "garnet_spec"

module SystemTest
  DRIVER = :chrome
  PATH = "/usr/local/bin/chromedriver"
end

Writing SystemTests

require "spec_helper"

class SomeFeatureSpec < GarnetSpec::System::Test
  describe "Some Feature test" do
    it "works" do
      visit "http://crystal-lang.org/api"
      fill "", "Client", "search"

      types_list = page.find_element(:id, "types-list")
      types = types_list.find_elements(:css, "li:not([class~='hide'])")

      types.size.should eq 512
    end
  end
end

Run your crystal spec

crystal spec

Development

  • [ ] Add support for other webdrivers
  • [ ] Add more dsl methods similar to https://gist.github.com/zhengjia/428105
  • [ ] Add support for Chrome webdriver Desired Capabilities
  • [ ] Add support for headless chrome
  • [ ] Make it more configurable

Contributing

  1. Fork it ( https://github.com/amberframework/garnet-spec/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors