Skip to content

TypeScript testing framework with test cases

License

Notifications You must be signed in to change notification settings

tcolar/alsatian

 
 

Repository files navigation

Alsatian Mascot Logo

Awesomely easy and useful TypeScript and JavaScript testing framework with test cases, compatible with selenium, coverage checkers and TAP reporters.

NPM Version License Linux and OSX Build Status Windows Build Status Code Climate Coverage Status Code Climate Issue Count Known Vulnerabilities

v3.0.0 is in ALPHA

We're getting ready to release 3.0.0 and we'd love your feedback. We are still developing features fully but for the most part they should be there but perhaps with some bugs. The goal of alpha is to get feedback about API changes and finish features so if you've got any feedback or would like to help please raise an issue or get in touch :) Info about the release can be found on our Roadmap

You can install via npm install alsatian@alpha. We hope you love the new features and look forward to hearing from you guys

Quick Start

If you're loving TypeScript then pop on down to our TypeScript Quick Start.

Otherwise if you're more of a JavaScript kinda person, have a gander at our JavaScript Quick Start

Full documentation can be found on our wiki the examples are usually in TypeScript but should be pretty much the same code for JavaScript (just lose the access modifiers and types).

Alsatian is different

Using a different approach than other JavaScript test frameworks allows us to use more powerful patterns.

// no globals and typing support out of the box with intellisense
import { AsyncTest, Expect, Test, TestCase, TestFixture } from "alsatian";

@TestFixture("whatever you'd like to call the fixture")
export class SetOfTests {
    
    // use the async/await pattern in your tests as you would in your code
    @AsyncTest("asychronous test")
    public async asyncTest() {
        const response = await somethingToHappen();

        Expect(response).toBeDefined();
    }

    // pass arguments into your test functions to keep your test code from being repetative
    @TestCase(2, 2, 4)
    @TestCase(2, 3, 5)
    @TestCase(3, 3, 6)
    @Test("addition tests")
    public addTest(firstNumber: number, secondNumber: number, expectedSum: number) {
        Expect(firstNumber + secondNumber).toBe(expectedSum);
    }
}

Why would I use Alsatian?

The key question! Well Alsatian has a lot going for it here are just a few great things to note:

  • All the awesome features you love from existing frameworks
  • The TestCase decorator allows you to write smaller, DRY and more readable tests
  • No globals!
  • TAP support so you can use your favourite TAP reporter
  • Great CI process, every pull request and push on every branch is scrutinised to ensure high quality
  • 100% coverage all statements, lines, branches are covered in Alsatian tests
  • Various services rate us very highly on lots of different factors, check out our badges
  • Everything is documented in a friendly and simple way to help you get to the unit test setup of your dreams
  • Being written in TypeScript it fits perfectly into your TypeScript but still compatible with JavaScript too!
  • Active support - if you've got a question, a suggestion or found an issue let us know and we'll get back to you quickly

Also it's lightning fast, watch it run all of it's unit tests in super quick time! Alsatian Test Run Video

Besides unit tests, what can I do with Alsatian

So many awesome things!

  • write end to end tests with Selenium
  • check your code coverage with NYC
  • set up a wonderful CI process and give confidence in the quality of your product
  • have the output look however you desire using TAP reporters

Support

If at any time things are unclear or you think there may be something going wrong feel free to raise an issue and we'll be glad to get back to you with a solution quickly.

Contributing

We're always glad to have help out with Alsatian, check out the guidelines

License

Alsatian has been released under the MIT license

About

TypeScript testing framework with test cases

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 98.7%
  • JavaScript 1.3%