npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

unit-testing.ahk

v0.6.1

Published

Simple unit testing class to perform and report tests for AutoHotkey projects

Downloads

50

Readme

unit-testing.ahk

A unit test framework for AutoHotkey

Installation

In a terminal or command line navigated to your project folder:

npm install unit-testing.ahk

In your code:

#Include %A_ScriptDir%\node_modules
#Include unit-testing.ahk\export.ahk
assert := new unittesting.ahk

testVar := 2 + 2
assert.equal(testVar, 4)
assert.fullReport()

You may also review or copy the library from ./export.ahk on GitHub; #Include as you would normally when manually downloading.

Usage

Grants access to a class named unittesting with the following methods: .equal, .true, .false, .notEqual, .label, .report, .fullReport, and .writeTestResultsToFile

assert := new unittesting()

; .equal checks and logs whether or not both arguments are the same
assert.label("string comparison")
assert.equal("StringExample", "StringExample")

assert.label("value testing")
assert.equal((1 > 0 ), true)

assert.label("true/false testing")
assert.true((1 == 1))
assert.false((1 != 1))
assert.notEqual(true,false)

assert.report()
assert.fullReport()
assert.writeTestResultsToFile()

API

.equal(actual, expected)

Alias: .test

checks if actual and expected are the same or equal. The comparison is case-insensitive when ahk is inStringCaseSense, Off (default ahk behavior)

Arguments
  1. actual (*): The actual value computed
  2. expected (*): The expected value
Returns

(boolean): returns true if the values were the same, else false

Example
assert.equal("string", "tsring")
; => false

assert.equal((1 > 0 ), true)
; => true

.true(actual)

checks if actual value is true.

Arguments
  1. actual (*): The actual value computed
Returns

(boolean): returns true if the value is true, else false

Example
assert.true((1 == 1))
; => true

assert.true(InStr("String", "S"))
; => true

.false(actual)

checks if actual value is false.

Arguments
  1. actual (*): The actual value computed
Returns

(boolean): returns true if the value is false, else false

Example
assert.false((1 != 1))
; => true

assert.false(InStr("String", "X"))
; => true

.notEqual(actual, expected)

checks if actual and expected are NOT the same or equal. The comparison is case-insensitive when ahk is inStringCaseSense, Off (default ahk behavior)

Arguments
  1. actual (*): The actual value computed
  2. expected (*): The expected value
Returns

(boolean): returns true if the value is false, else false

Example
assert.false((1 != 1))
; => true

assert.false(InStr("String", "X"))
; => true

.undefined(actual)

checks if actual is undefined ("").

Arguments
  1. actual (*): The actual value computed
Returns

(boolean): returns true if the value is "", else false

Example
assert.false((1 != 1))
; => true

assert.false(InStr("String", "X"))
; => true

.label(label)

labels the following tests for logs and readability

Arguments
  1. label (string): A human readable label for the next test(s) in sequence
Example
assert.label("string comparisons")

assert.equal("String", "s")
assert.fullReport()
/*---------------------------
1 tests completed with 0% success (1 failure)
=================================
== string comparisons ==
Test Number: 1
Expected: s
Actual: String
---------------------------*/

.report()

Uses msgbox to display the results of all tests

Example
assert.true(InStr("String", "S"))

assert.report()
/*---------------------------
1 test completed with 100% success
---------------------------*/

.fullReport()

Uses msgbox to display the results of all tests with details of any failures

Example
assert.true(InStr("String", "X"))

assert.fullReport()
/*---------------------------
1 tests completed with 0% success (1 failure)
=================================
Test Number: 1
Expected: true
Actual: false
---------------------------*/

.writeTestResultsToFile([filepath])

writes test results to a file

Arguments
  1. filepath (string): Optional, The file path to write all tests results to, the default is A_ScriptDir "\result.tests.log"
Example
assert.true(InStr("String", "X"))

assert.writeTestResultsToFile()
/*Test Number: 1
Expected: true
Actual: false*/