2021-04-26 05:47:55 +00:00
|
|
|
import os.path
|
2021-04-28 07:58:25 +00:00
|
|
|
import unittest
|
2021-04-30 08:52:06 +00:00
|
|
|
import traceback
|
2021-04-28 07:58:25 +00:00
|
|
|
|
2021-04-26 05:47:55 +00:00
|
|
|
import git
|
2021-04-28 07:58:25 +00:00
|
|
|
from click.testing import CliRunner
|
2021-04-26 05:47:55 +00:00
|
|
|
|
2021-04-28 08:02:22 +00:00
|
|
|
import yaclog.changelog
|
2021-04-26 05:47:55 +00:00
|
|
|
from yaclog.cli.__main__ import cli
|
|
|
|
|
|
|
|
|
2021-04-30 05:59:09 +00:00
|
|
|
def check_result(runner, result, success: bool = True):
|
2021-04-30 08:52:06 +00:00
|
|
|
runner.assertEqual((result.exit_code == 0), success,
|
|
|
|
f'\noutput: {result.output}\ntraceback: ' + ''.join(
|
|
|
|
traceback.format_exception(*result.exc_info)))
|
2021-04-26 06:18:44 +00:00
|
|
|
|
|
|
|
|
2021-04-26 05:47:55 +00:00
|
|
|
class TestCreation(unittest.TestCase):
|
|
|
|
def test_init(self):
|
|
|
|
"""Test creating and overwriting a changelog"""
|
|
|
|
runner = CliRunner()
|
|
|
|
location = 'CHANGELOG.md'
|
|
|
|
err_str = 'THIS FILE WILL BE OVERWRITTEN'
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
result = runner.invoke(cli, ['init'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
self.assertTrue(os.path.exists(os.path.abspath(location)), 'yaclog init did not create a file')
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn(location, result.output, "yaclog init did not echo the file's correct location")
|
2021-04-26 05:47:55 +00:00
|
|
|
|
2021-05-10 02:39:48 +00:00
|
|
|
with open(location, 'r') as fp:
|
|
|
|
self.assertEqual('# Changelog\n', fp.readline())
|
|
|
|
self.assertEqual('\n', fp.readline())
|
|
|
|
self.assertEqual('All notable changes to this project will be documented in this file',
|
|
|
|
fp.readline().rstrip())
|
|
|
|
|
2021-04-26 05:47:55 +00:00
|
|
|
with open(location, 'w') as fp:
|
|
|
|
fp.write(err_str)
|
|
|
|
|
|
|
|
result = runner.invoke(cli, ['init'], input='y\n')
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
self.assertTrue(os.path.exists(os.path.abspath(location)), 'file no longer exists after overwrite')
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn(location, result.output, "yaclog init did not echo the file's correct location")
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
with open(location, 'r') as fp:
|
|
|
|
self.assertNotEqual(fp.read(), err_str, 'file was not overwritten')
|
|
|
|
|
|
|
|
def test_init_path(self):
|
|
|
|
"""Test creating a changelog with a non-default filename"""
|
|
|
|
runner = CliRunner()
|
|
|
|
location = 'A different file.md'
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
result = runner.invoke(cli, ['--path', location, 'init'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
self.assertTrue(os.path.exists(os.path.abspath(location)), 'yaclog init did not create a file')
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn(location, result.output, "yaclog init did not echo the file's correct location")
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
def test_does_not_exist(self):
|
|
|
|
"""Test if an error is thrown when the file does not exist"""
|
|
|
|
runner = CliRunner()
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
result = runner.invoke(cli, ['show'])
|
2021-04-30 05:59:09 +00:00
|
|
|
check_result(self, result, False)
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn('does not exist', result.output)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TestTagging(unittest.TestCase):
|
|
|
|
def test_tag_addition(self):
|
2021-04-27 02:53:28 +00:00
|
|
|
"""Test adding tags to versions"""
|
2021-04-26 05:47:55 +00:00
|
|
|
runner = CliRunner()
|
|
|
|
location = 'CHANGELOG.md'
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
in_log = yaclog.Changelog(location)
|
2021-04-28 08:02:22 +00:00
|
|
|
in_log.versions = [yaclog.changelog.VersionEntry(), yaclog.changelog.VersionEntry()]
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
in_log.versions[0].name = '1.0.0'
|
|
|
|
in_log.versions[1].name = '0.9.0'
|
|
|
|
in_log.write()
|
|
|
|
|
|
|
|
result = runner.invoke(cli, ['tag', 'tag1'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
result = runner.invoke(cli, ['tag', 'tag2', '0.9.0'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
out_log = yaclog.read(location)
|
|
|
|
self.assertEqual(out_log.versions[0].tags, ['TAG1'])
|
|
|
|
self.assertEqual(out_log.versions[1].tags, ['TAG2'])
|
|
|
|
|
|
|
|
result = runner.invoke(cli, ['tag', 'tag3', '0.8.0'])
|
2021-04-30 05:59:09 +00:00
|
|
|
check_result(self, result, False)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
def test_tag_deletion(self):
|
2021-04-27 02:53:28 +00:00
|
|
|
"""Test deleting tags from versions"""
|
2021-04-26 05:47:55 +00:00
|
|
|
runner = CliRunner()
|
|
|
|
location = 'CHANGELOG.md'
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
in_log = yaclog.Changelog(location)
|
|
|
|
in_log.versions = [None, None]
|
2021-04-28 08:02:22 +00:00
|
|
|
in_log.versions = [yaclog.changelog.VersionEntry(), yaclog.changelog.VersionEntry()]
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
in_log.versions[0].name = '1.0.0'
|
|
|
|
in_log.versions[0].tags = ['TAG1']
|
|
|
|
|
|
|
|
in_log.versions[1].name = '0.9.0'
|
|
|
|
in_log.versions[1].tags = ['TAG2']
|
|
|
|
in_log.write()
|
|
|
|
|
|
|
|
result = runner.invoke(cli, ['tag', '-d', 'tag2', '0.8.0'])
|
2021-04-30 05:59:09 +00:00
|
|
|
check_result(self, result, False)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
result = runner.invoke(cli, ['tag', '-d', 'tag3', '0.9.0'])
|
2021-04-30 05:59:09 +00:00
|
|
|
check_result(self, result, False)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
result = runner.invoke(cli, ['tag', '-d', 'tag1'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
out_log = yaclog.read(location)
|
|
|
|
self.assertEqual(out_log.versions[0].tags, [])
|
|
|
|
self.assertEqual(out_log.versions[1].tags, ['TAG2'])
|
|
|
|
|
|
|
|
result = runner.invoke(cli, ['tag', '-d', 'tag2', '0.9.0'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
out_log = yaclog.read(location)
|
|
|
|
self.assertEqual(out_log.versions[0].tags, [])
|
|
|
|
self.assertEqual(out_log.versions[1].tags, [])
|
|
|
|
|
|
|
|
|
|
|
|
class TestRelease(unittest.TestCase):
|
|
|
|
def test_increment(self):
|
2021-04-27 02:53:28 +00:00
|
|
|
"""Test version incrementing on release"""
|
2021-04-26 05:47:55 +00:00
|
|
|
runner = CliRunner()
|
|
|
|
location = 'CHANGELOG.md'
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
runner.invoke(cli, ['init']) # create the changelog
|
|
|
|
runner.invoke(cli, ['entry', '-b', 'entry number 1'])
|
|
|
|
|
2021-05-07 20:57:01 +00:00
|
|
|
result = runner.invoke(cli, ['release', '1.0.0'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '1.0.0')
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn('1.0.0', result.output)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
runner.invoke(cli, ['entry', '-b', 'entry number 2'])
|
|
|
|
|
2021-04-26 06:05:16 +00:00
|
|
|
result = runner.invoke(cli, ['release', '-p'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '1.0.1')
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn('1.0.1', result.output)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
runner.invoke(cli, ['entry', '-b', 'entry number 3'])
|
|
|
|
|
2021-04-26 06:05:16 +00:00
|
|
|
result = runner.invoke(cli, ['release', '-m'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '1.1.0')
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn('1.1.0', result.output)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
|
|
|
runner.invoke(cli, ['entry', '-b', 'entry number 4'])
|
|
|
|
|
2021-04-26 06:05:16 +00:00
|
|
|
result = runner.invoke(cli, ['release', '-M'])
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 05:47:55 +00:00
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '2.0.0')
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn('2.0.0', result.output)
|
2021-04-26 05:47:55 +00:00
|
|
|
|
2021-05-01 04:19:04 +00:00
|
|
|
runner.invoke(cli, ['entry', '-b', 'entry number 5'])
|
|
|
|
|
|
|
|
result = runner.invoke(cli, ['release', '-Ma'])
|
|
|
|
check_result(self, result)
|
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '3.0.0a1')
|
|
|
|
self.assertIn('3.0.0a1', result.output)
|
|
|
|
|
|
|
|
result = runner.invoke(cli, ['release', '-b'])
|
|
|
|
check_result(self, result)
|
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '3.0.0b1')
|
|
|
|
self.assertIn('3.0.0b1', result.output)
|
|
|
|
|
|
|
|
result = runner.invoke(cli, ['release', '-r'])
|
|
|
|
check_result(self, result)
|
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '3.0.0rc1')
|
|
|
|
self.assertIn('3.0.0rc1', result.output)
|
|
|
|
|
2021-05-07 20:57:01 +00:00
|
|
|
result = runner.invoke(cli, ['release', '-r'])
|
|
|
|
check_result(self, result)
|
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '3.0.0rc2')
|
|
|
|
self.assertIn('3.0.0rc1', result.output)
|
|
|
|
|
2021-05-01 04:19:04 +00:00
|
|
|
result = runner.invoke(cli, ['release', '-f'])
|
|
|
|
check_result(self, result)
|
|
|
|
self.assertEqual(yaclog.read(location).versions[0].name, '3.0.0')
|
|
|
|
self.assertIn('3.0.0', result.output)
|
|
|
|
|
2021-04-26 05:47:55 +00:00
|
|
|
def test_commit(self):
|
2021-04-27 02:53:28 +00:00
|
|
|
"""Test committing and tagging releases"""
|
2021-04-26 05:47:55 +00:00
|
|
|
runner = CliRunner()
|
|
|
|
|
|
|
|
with runner.isolated_filesystem():
|
|
|
|
repo = git.Repo.init(os.path.join(os.curdir, 'testing'))
|
|
|
|
os.chdir('testing')
|
|
|
|
repo.index.commit('initial commit')
|
|
|
|
|
2021-04-26 06:18:44 +00:00
|
|
|
with repo.config_writer() as cw:
|
|
|
|
cw.set_value('user', 'email', 'unit-tester@example.com')
|
|
|
|
cw.set_value('user', 'name', 'unit-tester')
|
|
|
|
|
2021-04-26 05:47:55 +00:00
|
|
|
runner.invoke(cli, ['init']) # create the changelog
|
|
|
|
runner.invoke(cli, ['entry', '-b', 'entry number 1'])
|
|
|
|
|
2021-05-12 02:23:21 +00:00
|
|
|
result = runner.invoke(cli, ['release', 'Version 1.0.0', '-c'], input='y\n')
|
2021-04-26 06:18:44 +00:00
|
|
|
check_result(self, result)
|
2021-04-26 06:05:16 +00:00
|
|
|
self.assertIn('Created commit', result.output)
|
|
|
|
self.assertIn('Created tag', result.output)
|
|
|
|
self.assertIn(repo.head.commit.hexsha[0:7], result.output)
|
2021-04-26 05:47:55 +00:00
|
|
|
self.assertEqual(repo.tags[0].name, '1.0.0')
|
|
|
|
|
|
|
|
|
2021-05-12 05:10:13 +00:00
|
|
|
class TestShow(unittest.TestCase):
|
|
|
|
|
|
|
|
# noinspection PyShadowingNames
|
|
|
|
def setUp(self):
|
|
|
|
self.runner = CliRunner()
|
|
|
|
self.location = 'CHANGELOG.md'
|
|
|
|
|
|
|
|
self.log = yaclog.Changelog()
|
|
|
|
|
|
|
|
self.log.add_version(name='1.0.0').add_entry('- entry number 1')
|
|
|
|
self.log.add_version(name='Version 2.0.0').add_entry('- entry number 2', 'Added')
|
|
|
|
self.log.add_version(name='Three Point Oh').add_entry('entry number 3')
|
|
|
|
v = self.log.add_version(name='4.0.0 "Euclid"')
|
|
|
|
v.add_entry('- entry number 4')
|
|
|
|
v.add_entry('- entry number 5')
|
|
|
|
v.tags.append('TAGGED')
|
|
|
|
|
|
|
|
self.modes = {
|
|
|
|
'full': ([], lambda v, k: v.text(**k), '\n\n'),
|
|
|
|
'name': (['-n'], lambda v, k: v.name, '\n'),
|
|
|
|
'body': (['-b'], lambda v, k: v.body(**k), '\n\n'),
|
|
|
|
'header': (['-h'], lambda v, k: v.header(**k), '\n'),
|
|
|
|
}
|
|
|
|
|
|
|
|
def test_show_all(self):
|
|
|
|
"""Test showing all version information"""
|
|
|
|
|
|
|
|
with self.runner.isolated_filesystem():
|
|
|
|
self.log.write(self.location)
|
|
|
|
|
|
|
|
for mode, t in self.modes.items():
|
|
|
|
with self.subTest(mode, flags=t[0]):
|
|
|
|
check_result(self, result := self.runner.invoke(cli, ['show', '-a'] + t[0]))
|
|
|
|
self.assertEqual(t[2].join([t[1](v, {'md': False}) for v in self.log.versions]),
|
|
|
|
result.output.strip(), 'incorrect plaintext output')
|
|
|
|
|
|
|
|
check_result(self, result := self.runner.invoke(cli, ['show', '-am'] + t[0]))
|
|
|
|
self.assertEqual(t[2].join([t[1](v, {'md': True}) for v in self.log.versions]),
|
|
|
|
result.output.strip(), 'incorrect markdown output')
|
|
|
|
|
|
|
|
def test_show_version(self):
|
|
|
|
with self.runner.isolated_filesystem():
|
|
|
|
self.log.write(self.location)
|
|
|
|
|
|
|
|
for mode, t in self.modes.items():
|
|
|
|
with self.subTest(mode, flags=t[0]):
|
|
|
|
|
|
|
|
for version in self.log.versions:
|
|
|
|
check_result(self, result := self.runner.invoke(cli, ['show', version.name] + t[0]))
|
|
|
|
self.assertEqual(t[1](version, {'md': False}),
|
|
|
|
result.output.strip(), 'incorrect plaintext output')
|
|
|
|
|
|
|
|
check_result(self, result := self.runner.invoke(cli, ['show', version.name[-5:]] + t[0]))
|
|
|
|
self.assertEqual(t[1](version, {'md': False}),
|
|
|
|
result.output.strip(), 'incorrect plaintext output')
|
|
|
|
|
|
|
|
check_result(self, result := self.runner.invoke(cli, ['show', version.name, '-m'] + t[0]))
|
|
|
|
self.assertEqual(t[1](version, {'md': True}),
|
|
|
|
result.output.strip(), 'incorrect markdown output')
|
|
|
|
|
|
|
|
check_result(self, result := self.runner.invoke(cli, ['show', version.name[-5:], '-m'] + t[0]))
|
|
|
|
self.assertEqual(t[1](version, {'md': True}),
|
|
|
|
result.output.strip(), 'incorrect markdown output')
|
|
|
|
|
|
|
|
|
2021-04-26 05:47:55 +00:00
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|