Using RSPEC to create a functional test for broad and high impact network changes. Allowing you to increase the pereferal knowledge of impact during your change. Use this instead of manually pinging X hosts and arbitrarily refreshing Y web browser.
You are encouraged to create a collection of tests that are quickly executed and easily looped. You no lnoger have to wait on a sluggish NMS to tell something is broke. The cost of adding items to monitor in a site_test is cheap so there is no excuse not to have as comprehensive list of checks as possible.
Site tests are easy to read and share. Anyone should be able to understand the intent of the checks. You can now build templates for any number routine maintenances you do.
Test driven methodolgies are good practices beyond the world of software development.
# mytest.txt
#site sitename
site Load balancer failover
icmp 10.0.0.3 true
icmp 10.0.0.2 true # Will ping false during the maintenance but should recover once completed
icmp 10.0.0.1 true # Vip should always ping true. If it fails ensure that the new active ARP'd for ownership of that VIP
#Site should remain up during the maintenance
http www.mywebsite.com 200
ssl www.mywebsite.com 0 #If the other LB has a bad cert on the VIP this will alert
#Make sure that the DNS VIP still works. Test an internal property agains`
dns service.internal.mywebsite.com 10.10.0.100 10.0.0.15
$ test_my mytest.txt
......
Finished in 1.15 seconds (files took 0.09136 seconds to load)
6 examples, 0 failures
$
git clone https://github.com/crosson/site_test
cd site_test/site_test/
gem install site_test
cd ~/bin
ln -s [path to site_test git repo]/test_my.rb test_my
Site Test is just a wrapper around RSPEC. It reads a text file you create and runs a series of tests against it. These are the current tests supported.
- ICMP Ping
- HTTP Codes
- DNS
- SSL
- HTML Parsing*
- SMTP*
- MYSQL*
SMTP, Mysql and HTML parsing are currently making system calls. I plan on replacing these with native ruby solutions soon.
- Install the site_test gem.
- symlink test_my.rb and add it to your path.
- Create a site test. See the example file
- Run your tests.
$ test_my mytest.txt
.........
Finished in 1.38 seconds (files took 0.0926 seconds to load)
9 examples, 0 failures
$
What it looks like when something fails.
$ test_my mytest.txt
F......F.
Failures:
1) Mytest check >> ICMP: Check >> 127.0.0.1 should ping false >>
Failure/Error: expect(ping(host[:hostname])).to be expected
expected false
got true
# /Users/crosson/bin/test_my:39:in `block (4 levels) in <main>'
2) Mytest check >> HTTP: Check >> https://store.apple.com/ should result in 200 >>
Failure/Error: expect(http_code(address[:address])).to eq address[:expected_result]
expected: 200
got: 301
(compared using ==)
# /Users/crosson/bin/test_my:59:in `block (4 levels) in <main>'
Finished in 1.56 seconds (files took 0.09239 seconds to load)
9 examples, 2 failures
Failed examples:
rspec /Users/crosson/bin/test_my[1:1:1] # Mytest check >> ICMP: Check >> 127.0.0.1 should ping false >>
rspec /Users/crosson/bin/test_my[1:3:2] # Mytest check >> HTTP: Check >> https://store.apple.com/ should result in 200 >>
$
The test tells you exactly what it expected and what it recieved instead.
You get access to all rspecs flags. Normally your site_test will only output errors after the test is completed. Typically you will have this running in a loop during your maintenance but sometimes you may want detailed output in realtime for documentation later.
Try using the --format documentation flag.
$ test_my mytest.txt --format documentation
Mytest check >>
ICMP: Check >>
127.0.0.1 should ping false >> (FAILED - 1)
8.8.8.8 should ping true >>
1.2.3.4 should ping false >>
www.google.com should ping true >>
DNS: Check >>
www.summitatsnoqualmie.com should resolve to 96.31.166.53 >>
nwac.com should resolve to 67.195.61.46 >>
HTTP: Check >>
www.google.com should result in 200 >>
https://store.apple.com/ should result in 200 >> (FAILED - 2)
SSL: Check >>
SSL www.google.com should result in 0 >>
Failures:
1) Mytest check >> ICMP: Check >> 127.0.0.1 should ping false >>
Failure/Error: expect(ping(host[:hostname])).to be expected
expected false
got true
# /Users/crosson/bin/test_my:39:in `block (4 levels) in <main>'
2) Mytest check >> HTTP: Check >> https://store.apple.com/ should result in 200 >>
Failure/Error: expect(http_code(address[:address])).to eq address[:expected_result]
expected: 200
got: 301
(compared using ==)
# /Users/crosson/bin/test_my:59:in `block (4 levels) in <main>'
Finished in 1.95 seconds (files took 0.09442 seconds to load)
9 examples, 2 failures
Failed examples:
rspec /Users/crosson/bin/test_my[1:1:1] # Mytest check >> ICMP: Check >> 127.0.0.1 should ping false >>
rspec /Users/crosson/bin/test_my[1:3:2] # Mytest check >> HTTP: Check >> https://store.apple.com/ should result in 200 >>
$
Loop your test using the --format html flag and --out flag. Run a simple HTTP server and see your test results in real time in a web browser.
test_my mytest.txt --format html --out mytest.html
If you want to experiment with more flags review with rspec -h.
- Update MYSQL Method
- Update SMTP Method
- Update HTML Parsing method and review performance
- Add a TCP Ping method