From 1f5146e7a05a4a719fca25d50a886f21393f09cc Mon Sep 17 00:00:00 2001 From: Paul Beckingham Date: Sun, 26 Feb 2012 13:39:55 -0500 Subject: [PATCH] Unit Tests - Corrected test count and removed diag output. --- test/feature.725.t | 76 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) create mode 100755 test/feature.725.t diff --git a/test/feature.725.t b/test/feature.725.t new file mode 100755 index 000000000..5e4b1bc7f --- /dev/null +++ b/test/feature.725.t @@ -0,0 +1,76 @@ +#! /usr/bin/perl +################################################################################ +## taskwarrior - a command line task list manager. +## +## Copyright 2006-2012, Paul Beckingham, Federico Hernandez. +## +## Permission is hereby granted, free of charge, to any person obtaining a copy +## of this software and associated documentation files (the "Software"), to deal +## in the Software without restriction, including without limitation the rights +## to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +## copies of the Software, and to permit persons to whom the Software is +## furnished to do so, subject to the following conditions: +## +## The above copyright notice and this permission notice shall be included +## in all copies or substantial portions of the Software. +## +## THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +## OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +## FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +## THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +## LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +## OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +## SOFTWARE. +## +## http://www.opensource.org/licenses/mit-license.php +## +################################################################################ + +use strict; +use warnings; +use Test::More tests => 8; + +# Create the rc file. +if (open my $fh, '>', 'feature.rc') +{ + print $fh "data.location=.\n", + "confirmation=off\n"; + close $fh; + ok (-r 'feature.rc', 'Created feature.rc'); +} + +# Feature 725: Feedback when tasks become unblocked. +qx{../src/task rc:feature.rc add one}; +qx{../src/task rc:feature.rc add two}; +qx{../src/task rc:feature.rc add three}; +qx{../src/task rc:feature.rc add four}; +qx{../src/task rc:feature.rc 1 modify depends:2,3}; +qx{../src/task rc:feature.rc 4 modify depends:1}; +my $output = qx{../src/task rc:feature.rc long}; +like ($output, qr/1.+2\s3/, 'Dependencies in place [1]'); +like ($output, qr/4.+1/, 'Dependencies in place [4]'); + +# Trigger the feedback based on completion. +$output = qx{../src/task rc:feature.rc 2 done}; +unlike ($output, qr/Unblocked/, 'Completing first dependency does not trigger message'); + +$output = qx{../src/task rc:feature.rc 3 done}; +like ($output, qr/Unblocked/, 'Completing second dependency triggers message'); + +# Now trigger the feedback based on deletion. +$output = qx{../src/task rc:feature.rc long}; +like ($output, qr/2.+1/, 'Dependencies in place [2]'); +$output = qx{../src/task rc:feature.rc 1 delete}; +like ($output, qr/Unblocked/, 'Deleting dependency triggers message'); + +# Cleanup. +unlink qw(pending.data completed.data undo.data backlog.data synch.key feature.rc); +ok (! -r 'pending.data' && + ! -r 'completed.data' && + ! -r 'undo.data' && + ! -r 'backlog.data' && + ! -r 'synch.key' && + ! -r 'feature.rc', 'Cleanup'); + +exit 0; +