diff options
| author | Simon Hausmann <simon.hausmann@nokia.com> | 2012-01-06 14:44:00 +0100 | 
|---|---|---|
| committer | Simon Hausmann <simon.hausmann@nokia.com> | 2012-01-06 14:44:00 +0100 | 
| commit | 40736c5763bf61337c8c14e16d8587db021a87d4 (patch) | |
| tree | b17a9c00042ad89cb1308e2484491799aa14e9f8 /Tools/Scripts/webkitpy/common/net/htdigestparser_unittest.py | |
| download | qtwebkit-40736c5763bf61337c8c14e16d8587db021a87d4.tar.gz | |
Imported WebKit commit 2ea9d364d0f6efa8fa64acf19f451504c59be0e4 (http://svn.webkit.org/repository/webkit/trunk@104285)
Diffstat (limited to 'Tools/Scripts/webkitpy/common/net/htdigestparser_unittest.py')
| -rw-r--r-- | Tools/Scripts/webkitpy/common/net/htdigestparser_unittest.py | 82 | 
1 files changed, 82 insertions, 0 deletions
| diff --git a/Tools/Scripts/webkitpy/common/net/htdigestparser_unittest.py b/Tools/Scripts/webkitpy/common/net/htdigestparser_unittest.py new file mode 100644 index 000000000..a2a4ac938 --- /dev/null +++ b/Tools/Scripts/webkitpy/common/net/htdigestparser_unittest.py @@ -0,0 +1,82 @@ +# Copyright (C) 2011 Apple Inc. All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions +# are met: +# 1.  Redistributions of source code must retain the above copyright +#     notice, this list of conditions and the following disclaimer. +# 2.  Redistributions in binary form must reproduce the above copyright +#     notice, this list of conditions and the following disclaimer in the +#     documentation and/or other materials provided with the distribution. +# +# THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND +# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +# DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR +# ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +import StringIO +import os +import unittest + +from webkitpy.common.net.htdigestparser import HTDigestParser + + +class HTDigestParserTest(unittest.TestCase): +    def assertEntriesEqual(self, entries, additional_content=None): +        digest_file = self.fake_htdigest_file() +        if additional_content is not None: +            digest_file.seek(pos=0, mode=os.SEEK_END) +            digest_file.write(additional_content) +            digest_file.seek(pos=0, mode=os.SEEK_SET) +        self.assertEqual(entries, HTDigestParser(digest_file).entries()) + +    def test_authenticate(self): +        htdigest = HTDigestParser(self.fake_htdigest_file()) +        self.assertTrue(htdigest.authenticate('user1', 'realm 1', 'password1')) +        self.assertTrue(htdigest.authenticate('user2', 'realm 2', 'password2')) +        self.assertTrue(htdigest.authenticate('user3', 'realm 1', 'password3')) +        self.assertTrue(htdigest.authenticate('user3', 'realm 3', 'password3')) + +        self.assertFalse(htdigest.authenticate('user1', 'realm', 'password1')) +        self.assertFalse(htdigest.authenticate('user1', 'realm 2', 'password1')) +        self.assertFalse(htdigest.authenticate('user2', 'realm 2', 'password1')) +        self.assertFalse(htdigest.authenticate('user2', 'realm 1', 'password1')) +        self.assertFalse(htdigest.authenticate('', '', '')) + +    def test_entries(self): +        entries = [ +            ['user1', 'realm 1', '36b8aa27fa5e9051095d37b619f92762'], +            ['user2', 'realm 2', '14f827686fa97778f02fe1314a3337c8'], +            ['user3', 'realm 1', '1817fc8a24119cc57fbafc8a630ea5a5'], +            ['user3', 'realm 3', 'a05f5a2335e9d87bbe75bbe5e53248f0'], +        ] +        self.assertEntriesEqual(entries) +        self.assertEntriesEqual(entries, additional_content='') + +    def test_empty_file(self): +        self.assertEqual([], HTDigestParser(StringIO.StringIO()).entries()) + +    def test_too_few_colons(self): +        self.assertEntriesEqual([], additional_content='user1:realm 1\n') + +    def test_too_many_colons(self): +        self.assertEntriesEqual([], additional_content='user1:realm 1:36b8aa27fa5e9051095d37b619f92762:garbage\n') + +    def test_invalid_hash(self): +        self.assertEntriesEqual([], additional_content='user1:realm 1:36b8aa27fa5e9051095d37b619f92762000000\n') +        self.assertEntriesEqual([], additional_content='user1:realm 1:36b8aa27fa5e9051095d37b619f9276\n') +        self.assertEntriesEqual([], additional_content='user1:realm 1:36b8aa27fa5e9051095d37b619f9276z\n') +        self.assertEntriesEqual([], additional_content='user1:realm 1: 36b8aa27fa5e9051095d37b619f92762\n') + +    def fake_htdigest_file(self): +        return StringIO.StringIO("""user1:realm 1:36b8aa27fa5e9051095d37b619f92762 +user2:realm 2:14f827686fa97778f02fe1314a3337c8 +user3:realm 1:1817fc8a24119cc57fbafc8a630ea5a5 +user3:realm 3:a05f5a2335e9d87bbe75bbe5e53248f0 +""") | 
