Test: Merged bug.917.t into add.t

This commit is contained in:
Paul Beckingham 2015-07-12 16:18:49 -04:00
parent 17b230a6e0
commit 47fdcc661f
2 changed files with 10 additions and 63 deletions

View file

@ -81,6 +81,16 @@ class TestAdd(TestCase):
code, out, err = self.t("_get 3.description")
self.assertEqual(out, "release 3.0\n")
def test_escaped_quotes_are_preserved(self):
"""Verify that escaped quotes are preserved"""
# Bug 917: escaping runs amok
self.t("add one \\'two\\' three")
self.t("add four \\\"five\\\" six")
code, out, err = self.t("list")
self.assertIn("one 'two' three", out)
self.assertIn("four \"five\" six", out)
if __name__ == "__main__":
from simpletap import TAPTestRunner

View file

@ -1,63 +0,0 @@
#! /usr/bin/env perl
################################################################################
##
## Copyright 2006 - 2015, 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 => 4;
# Ensure environment has no influence.
delete $ENV{'TASKDATA'};
delete $ENV{'TASKRC'};
use File::Basename;
my $ut = basename ($0);
my $rc = $ut . '.rc';
# Create the rc file.
if (open my $fh, '>', $rc)
{
print $fh "data.location=.\n",
"confirmation=off\n";
close $fh;
}
# Bug 917: escaping runs amok
qx{../src/task rc:$rc add one \\'two\\' three 2>&1};
qx{../src/task rc:$rc add four \\"five\\" six 2>&1};
my $output = qx{../src/task rc:$rc list 2>&1};
like ($output, qr/one 'two' three/, "$ut: Single quote preserved");
like ($output, qr/four "five" six/, "$ut: Double quote preserved");
qx{../src/task rc:$rc 1,2 mod +tag 2>&1};
$output = qx{../src/task rc:$rc list 2>&1};
like ($output, qr/one 'two' three/, "$ut: Single quote preserved after modification");
like ($output, qr/four "five" six/, "$ut: Double quote preserved after modification");
# Cleanup.
unlink qw(pending.data completed.data undo.data backlog.data), $rc;
exit 0;