def setUp(self):
     self.client = GitClient()
class GitClientTestCase(TestCase):
    def setUp(self):
        self.client = GitClient()

    def test_base_command(self):
        self.assertEqual(self.client.base_command, 'git')

    def test_is_repository_with_repository(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'true'
            self.assertEqual(self.client.is_repository(), True)
            _check_output.assert_called_once_with(['git', 'rev-parse', '--is-inside-work-tree'])

    @without_git_repository('git', 'rev-parse', '--is-inside-work-tree')
    def test_is_repository_without_repository(self):
        self.assertEqual(self.client.is_repository(), False)

    def test_get_short_hash(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'3218766'
            self.assertEqual(self.client.get_short_hash(), '3218766')
            _check_output.assert_called_once_with(['git', 'rev-parse', '--short', 'HEAD'])

    @without_git_repository('git', 'rev-parse', 'HEAD')
    def test_get_short_hash_without_repository(self):
        self.assertEqual(self.client.get_short_hash(), None)

    def test_get_hash(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'32187666c7b6b7af6165f38aa8dbde4922d8423a'
            self.assertEqual(self.client.get_hash(), '32187666c7b6b7af6165f38aa8dbde4922d8423a')
            _check_output.assert_called_once_with(['git', 'rev-parse', 'HEAD'])

    @without_git_repository('git', 'rev-parse', 'HEAD')
    def test_get_hash_without_repository(self):
        self.assertEqual(self.client.get_hash(), None)

    def test_get_current_branch_name(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'master'
            self.assertEqual(self.client.get_current_branch_name(), 'master')
            _check_output.assert_called_once_with(['git', 'rev-parse', '--abbrev-ref', 'HEAD'])

    @without_git_repository('git', 'rev-parse', '--abbrev-ref', 'HEAD')
    def test_get_current_branch_name_without_repository(self):
        self.assertEqual(self.client.get_current_branch_name(), None)

    def test_get_author_name(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'giginet'
            self.assertEqual(self.client.get_author_name(), 'giginet')
            _check_output.assert_called_once_with(['git', 'show', '--quiet', '--format=%an', 'HEAD'])

    @without_git_repository('git', 'show', '--quiet', '--format=%an', 'HEAD')
    def test_get_author_name_without_repository(self):
        self.assertEqual(self.client.get_author_email(), None)

    def test_get_author_email(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'*****@*****.**'
            self.assertEqual(self.client.get_author_email(), '*****@*****.**')
            _check_output.assert_called_once_with(['git', 'show', '--quiet', '--format=%ae', 'HEAD'])

    @without_git_repository('git', 'show', '--quiet', '--format=%ae', 'HEAD')
    def test_get_author_email_without_repository(self):
        self.assertEqual(self.client.get_author_email(), None)

    def test_get_author_info(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'giginet<*****@*****.**>'
            self.assertEqual(self.client.get_author_info(), 'giginet<*****@*****.**>')
            _check_output.assert_called_once_with(['git', 'show', '--quiet', '--format=%an<%ae>', 'HEAD'])

    @without_git_repository('git', 'show', '--quiet', '--format=%an<%ae>', 'HEAD')
    def test_get_author_info_without_repository(self):
        self.assertEqual(self.client.get_author_info(), None)

    def test_get_committer_name(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'giginet'
            self.assertEqual(self.client.get_committer_name(), 'giginet')
            _check_output.assert_called_once_with(['git', 'show', '--quiet', '--format=%cn', 'HEAD'])

    @without_git_repository('git', 'show', '--quiet', '--format=%cn', 'HEAD')
    def test_get_committer_name_without_repository(self):
        self.assertEqual(self.client.get_committer_email(), None)

    def test_get_committer_email(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'*****@*****.**'
            self.assertEqual(self.client.get_committer_email(), '*****@*****.**')
            _check_output.assert_called_once_with(['git', 'show', '--quiet', '--format=%ce', 'HEAD'])

    @without_git_repository('git', 'show', '--quiet', '--format=%ce', 'HEAD')
    def test_get_committer_email_without_repository(self):
        self.assertEqual(self.client.get_committer_email(), None)

    def test_get_committer_info(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'giginet<*****@*****.**>'
            self.assertEqual(self.client.get_committer_info(), 'giginet<*****@*****.**>')
            _check_output.assert_called_once_with(['git', 'show', '--quiet', '--format=%cn<%ce>', 'HEAD'])

    @without_git_repository('git', 'show', '--quiet', '--format=%cn<%ce>', 'HEAD')
    def test_get_committer_info_without_repository(self):
        self.assertEqual(self.client.get_committer_info(), None)

    def test_get_date(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'2015-12-04 20:29:10 +0900'
            jst = pytz.timezone('Asia/Tokyo')
            self.assertEqual(self.client.get_date(), datetime.datetime(2015, 12, 4, 20, 29, 10, tzinfo=jst))
            _check_output.assert_called_once_with(['git', 'show', '--quiet', '--format=%ci', 'HEAD'])

    def test_get_date_with_invalid_return(self):
        with patch('subprocess.check_output') as _check_output:
            _check_output.return_value = b'2015-12-99'
            self.assertEqual(self.client.get_date(), None)
            _check_output.assert_called_once_with(['git', 'show', '--quiet', '--format=%ci', 'HEAD'])

    @without_git_repository('git', 'show', '--quiet', '--format=%ci', 'HEAD')
    def test_get_date_without_repository(self):
        self.assertEqual(self.client.get_date(), None)

    def test_get_message(self):
        with patch('subprocess.check_output') as _check_output:
            def check_output(commands):
                format = commands[-2]
                if format.endswith('%s'):
                    return b'Fix the issue'
                elif format.endswith('%b'):
                    return b'This commit will fix #10'
            _check_output.side_effect = check_output
            self.assertEqual(self.client.get_message(), 'Fix the issue\nThis commit will fix #10')

    def test_get_message_with_invalid_body(self):
        with patch('subprocess.check_output') as _check_output:
            def check_output(commands):
                format = commands[-2]
                if format.endswith('%s'):
                    return b'Fix the issue'
                elif format.endswith('%b'):
                    raise subprocess.CalledProcessError(128, ['git', 'show'])
            _check_output.side_effect = check_output
            self.assertEqual(self.client.get_message(), 'Fix the issue')

    @without_git_repository('git', 'show', '--quiet', '--format=%b', 'HEAD')
    def test_get_message_without_repository(self):
        self.assertEqual(self.client.get_message(), None)