irctest/README.md

93 lines
2.1 KiB
Markdown
Raw Normal View History

2015-12-18 16:26:55 +00:00
# irctest
2015-12-19 18:11:17 +00:00
This project aims at testing interoperability of software using the
IRC protocol, by running them against test suites and making different
software communicate with each other.
It is very young and does not contain a lot of test cases yet.
## The big picture
This project contains:
2015-12-19 22:57:22 +00:00
* IRC protocol test cases
2015-12-19 18:11:17 +00:00
* small wrappers around existing software to run tests on them
2015-12-19 22:57:22 +00:00
(only Limnoria, Sopel, and InspIRCd for the moment)
2015-12-19 18:11:17 +00:00
2015-12-19 22:57:22 +00:00
Wrappers run software in temporary directories, so running `irctest` should
have no side effect, with [the exception of Sopel](https://github.com/sopel-irc/sopel/issues/946).
2015-12-19 18:11:17 +00:00
2015-12-19 22:57:22 +00:00
## Prerequisites
2015-12-19 23:16:01 +00:00
Install irctest and dependencies:
2015-12-19 18:11:17 +00:00
```
2015-12-19 23:16:01 +00:00
git clone https://github.com/ProgVal/irctest.git
cd irctest
2015-12-19 18:11:17 +00:00
pip3 install --user -r requirements.txt
2015-12-19 23:16:01 +00:00
python3 setup.py install --user
2015-12-19 18:11:17 +00:00
```
2015-12-19 22:57:22 +00:00
Add `~/.local/bin/` to your `PATH` if it is not.
```
export PATH=$HOME/.local/bin/:$PATH
```
## Run tests
2015-12-21 21:54:03 +00:00
To run (client) tests on Limnoria:
2015-12-19 18:11:17 +00:00
```
pip3 install --user limnoria
python3 -m irctest irctest.controllers.limnoria
```
2015-12-21 21:54:03 +00:00
To run (client) tests on Sopel:
2015-12-19 18:11:17 +00:00
```
pip3 install --user sopel
mkdir ~/.sopel/
python3 -m irctest irctest.controllers.sopel
```
2015-12-19 22:57:22 +00:00
2015-12-21 21:54:03 +00:00
To run (server) tests on InspIRCd:
2015-12-19 22:57:22 +00:00
```
cd /tmp/
2015-12-19 23:16:01 +00:00
git clone https://github.com/inspircd/inspircd.git
2015-12-19 22:57:22 +00:00
cd inspircd
./configure --prefix=$HOME/.local/ --development
make -j 4
make install
python3 -m irctest irctest.controllers.inspircd
```
2015-12-21 21:54:03 +00:00
To run (server) tests on Mammon:
```
pip3 install --user git+https://github.com/mammon-ircd/mammon.git
python3 -m irctest irctest.controllers.mammon
```
To run (server) tests on Charybdis::
```
cd /tmp/
git clone https://github.com/atheme/charybdis.git
cd charybdis
./configure --prefix=$HOME/.local/
make -j 4
make install
python3 -m irctest irctest.controllers.charybdis
```
## What `irctest` is not
A formal proof that a given software follows any of the IRC specification,
or anything near that.
At best, `irctest` can help you find issues in your software, but it may
still have false positives (because it does not implement itself a
full-featured client/server, so it supports only “usual” behavior).