NAME
    Rex::Test::Spec - Write Rex::Test like RSpec!

VERSION
    Version 0.03

SYNOPSIS
        use Rex::Test::Spec;
        describe "Nginx Test", sub {
            context run("nginx -t"), "nginx.conf testing", sub {
                like its('stdout'), qr/ok/;
            };
            context file("~/.ssh/id_rsa"), sub {
                is its('ensure'), 'file';
                is its('mode'), '0600';
                like its('content'), qr/name\@email\.com/;
            };
            context file("/data"), sub {
                is its('ensure'), 'directory';
                is its('owner'), 'www';
                is its('mounted_on'), '/dev/sdb1';
                isnt its('writable');
            };
            context service("nginx"), sub {
                is its('ensure'), 'running';
            };
            context pkg("nginx"), sub {
                is its('ensure'), 'present';
                is its('version'), '1.5.8';
            };
            context cron, sub {
                like its('www'), 'logrotate';
            };
            context gateway, sub {
                is it, '192.168.0.1';
            };
            context group('www'), sub {
                ok its('ensure');
            };
            context iptables, sub {
            };
            context port(80), sub {
                is its('bind'), '0.0.0.0';
                is its('proto'), 'tcp';
                is its('command'), 'nginx';
            };
            context process('nginx'), sub {
                like its('command'), qr(nginx -c /etc/nginx.conf);
                ok its('mem') > 1024;
            };
            context routes, sub {
                is_deeply its(1), {
                    destination => $dest,
                    gateway     => $gw,
                    genmask     => $genmask,
                    flags       => $flags,
                    mss         => $mss,
                    irtt        => $irtt,
                    iface       => $iface,
                };
            };
            context sysctl, sub {
                is its('vm.swapiness'), 1;
            };
            context user('www'), sub {
                ok its('ensure');
                is its('home'), '/var/www/html';
                is its('shell'), '/sbin/nologin';
                is_deeply its('belong_to'), ['www', 'nogroup'];
            };
        };
        done_testing;

EXPORT FUNCTIONS
  Spec definition functions
    These are the functions you will use to define behaviors and run your
    specs: *describe* (and alias to *context*), *its* (alias to *it*).

    Normally suggest "describe "strings"" and "context resource type
    object", use "its(key)" return value, "it" return objects by default.

  Test::More export functions
    This now include *is*, *isnt*, *ok*, *is_deeply*, *like*, *unlike*,
    *done_testing*. You'll use these to assert correct behavior.

    The resource type name will be automatic passed as testing message.

  Rex resource type generation functions
    Now support *cron*, *gateway*, *iptables*, *port*, *routes*, *service*,
    *user*, *file*, *group*, *pkg*, *process*, *run*, *sysctl*.

    See "SYNOPSIS" for more details.

AUTHOR
    Rao Chenlin(chenryn), "<rao.chenlin at gmail.com>"

SEE ALSO
    1. Rspec
        <http://rspec.info/>

    2. Serverspec
        <http://serverspec.org/>

    3. TDD (Test Driven Development)
        <http://en.wikipedia.org/wiki/Test-driven_development>

    4. BDD (Behavior Driven Development)
        <http://en.wikipedia.org/wiki/Behavior_Driven_Development>

    5. Test::More
    6. Rex

BUGS
    Please report any bugs or feature requests to "bug-rex-test-spec at
    rt.cpan.org", or through the web interface at
    <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Rex-Test-Spec>. I will
    be notified, and then you'll automatically be notified of progress on
    your bug as I make changes.

    Also accept pull requests and issue at
    <https://github.com/chenryn/Rex--Test--Spec>.

LICENSE AND COPYRIGHT
    Copyright 2014 Rao Chenlin(chenryn).

    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at
    
    <http://www.apache.org/licenses/LICENSE-2.0>
    
    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.