15c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# Copyright (C) 2010 Apple Inc. All rights reserved.
25c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)#
35c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# Redistribution and use in source and binary forms, with or without
45c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# modification, are permitted provided that the following conditions
55c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# are met:
65c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# 1.  Redistributions of source code must retain the above copyright
75c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)#     notice, this list of conditions and the following disclaimer.
85c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# 2.  Redistributions in binary form must reproduce the above copyright
95c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)#     notice, this list of conditions and the following disclaimer in the
105c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)#     documentation and/or other materials provided with the distribution.
115c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)#
125c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND
135c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
145c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
155c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR
165c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
175c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
185c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
195c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
205c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
215c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
225c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
235c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)import StringIO
245c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)import logging
25e38fbeeb576b5094e34e038ab88d9d6a5c5c2214Torne (Richard Coles)import unittest
265c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
275c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)from webkitpy.test.skip import skip_if
285c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
295c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
305c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)class SkipTest(unittest.TestCase):
315c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)    def setUp(self):
325c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.logger = logging.getLogger(__name__)
335c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
345c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.old_level = self.logger.level
355c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.logger.setLevel(logging.INFO)
365c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
375c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.old_propagate = self.logger.propagate
385c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.logger.propagate = False
395c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
405c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.log_stream = StringIO.StringIO()
415c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.handler = logging.StreamHandler(self.log_stream)
425c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.logger.addHandler(self.handler)
435c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
445c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.foo_was_called = False
455c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
465c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)    def tearDown(self):
475c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.logger.removeHandler(self.handler)
485c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.propagate = self.old_propagate
495c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.logger.setLevel(self.old_level)
505c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
515c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)    def create_fixture_class(self):
525c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        class TestSkipFixture(object):
535c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)            def __init__(self, callback):
545c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)                self.callback = callback
555c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
565c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)            def test_foo(self):
575c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)                self.callback()
585c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
595c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        return TestSkipFixture
605c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
615c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)    def foo_callback(self):
625c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.foo_was_called = True
635c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
645c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)    def test_skip_if_false(self):
655c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        klass = skip_if(self.create_fixture_class(), False, 'Should not see this message.', logger=self.logger)
665c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        klass(self.foo_callback).test_foo()
675c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.assertEqual(self.log_stream.getvalue(), '')
685c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.assertTrue(self.foo_was_called)
695c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)
705c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)    def test_skip_if_true(self):
715c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        klass = skip_if(self.create_fixture_class(), True, 'Should see this message.', logger=self.logger)
725c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        klass(self.foo_callback).test_foo()
735c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.assertEqual(self.log_stream.getvalue(), 'Skipping webkitpy.test.skip_unittest.TestSkipFixture: Should see this message.\n')
745c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)        self.assertFalse(self.foo_was_called)
75