mirror of
https://github.com/drewcassidy/yaclog.git
synced 2024-09-01 14:58:58 +00:00
More CLI tests
This commit is contained in:
parent
3972786d82
commit
08be02a49c
3
.github/workflows/python-publish.yml
vendored
3
.github/workflows/python-publish.yml
vendored
@ -24,6 +24,9 @@ jobs:
|
|||||||
python -m pip install --upgrade pip
|
python -m pip install --upgrade pip
|
||||||
python -m pip install flake8
|
python -m pip install flake8
|
||||||
|
|
||||||
|
- name: Install module
|
||||||
|
run: python -m pip install .
|
||||||
|
|
||||||
- name: Lint with flake8
|
- name: Lint with flake8
|
||||||
run: |
|
run: |
|
||||||
# stop the build if there are Python syntax errors or undefined names
|
# stop the build if there are Python syntax errors or undefined names
|
||||||
|
@ -11,10 +11,8 @@ All notable changes to this project will be documented in this file
|
|||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
- Default links and dates in VersionEntry are now consistently `None`
|
- Default links and dates in VersionEntry are now consistently `None`
|
||||||
|
- Changelog links dict now contains version links.
|
||||||
### Fixed
|
Modified version links will overwrite those in the table when writing to a file
|
||||||
|
|
||||||
- Changelog links dict now contains version links. Modified version links will overwrite those in the table when writing to a file
|
|
||||||
- Changelog object no longer errors when creating without a path.
|
- Changelog object no longer errors when creating without a path.
|
||||||
- `release` now resets lesser version values when incrementing
|
- `release` now resets lesser version values when incrementing
|
||||||
- `release` now works with logs that have only unreleased changes
|
- `release` now works with logs that have only unreleased changes
|
||||||
|
177
tests/test_cli.py
Normal file
177
tests/test_cli.py
Normal file
@ -0,0 +1,177 @@
|
|||||||
|
import unittest
|
||||||
|
import os.path
|
||||||
|
import git
|
||||||
|
|
||||||
|
import yaclog
|
||||||
|
from yaclog.cli.__main__ import cli
|
||||||
|
from click.testing import CliRunner
|
||||||
|
|
||||||
|
|
||||||
|
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'])
|
||||||
|
self.assertEqual(result.exit_code, 0)
|
||||||
|
self.assertTrue(os.path.exists(os.path.abspath(location)), 'yaclog init did not create a file')
|
||||||
|
self.assertIn(location, result.stdout, "yaclog init did not echo the file's correct location")
|
||||||
|
|
||||||
|
with open(location, 'w') as fp:
|
||||||
|
fp.write(err_str)
|
||||||
|
|
||||||
|
result = runner.invoke(cli, ['init'], input='y\n')
|
||||||
|
self.assertEqual(result.exit_code, 0)
|
||||||
|
self.assertTrue(os.path.exists(os.path.abspath(location)), 'file no longer exists after overwrite')
|
||||||
|
self.assertIn(location, result.stdout, "yaclog init did not echo the file's correct location")
|
||||||
|
|
||||||
|
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'])
|
||||||
|
self.assertEqual(result.exit_code, 0)
|
||||||
|
self.assertTrue(os.path.exists(os.path.abspath(location)), 'yaclog init did not create a file')
|
||||||
|
self.assertIn(location, result.stdout, "yaclog init did not echo the file's correct location")
|
||||||
|
|
||||||
|
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'])
|
||||||
|
self.assertEqual(result.exit_code, 1)
|
||||||
|
self.assertIn('does not exist', result.stdout)
|
||||||
|
|
||||||
|
|
||||||
|
class TestTagging(unittest.TestCase):
|
||||||
|
def test_tag_addition(self):
|
||||||
|
runner = CliRunner()
|
||||||
|
location = 'CHANGELOG.md'
|
||||||
|
|
||||||
|
with runner.isolated_filesystem():
|
||||||
|
in_log = yaclog.Changelog(location)
|
||||||
|
in_log.versions = [yaclog.changelog.VersionEntry(), yaclog.changelog.VersionEntry()]
|
||||||
|
|
||||||
|
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'])
|
||||||
|
self.assertEqual(result.exit_code, 0)
|
||||||
|
|
||||||
|
result = runner.invoke(cli, ['tag', 'tag2', '0.9.0'])
|
||||||
|
self.assertEqual(result.exit_code, 0)
|
||||||
|
|
||||||
|
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'])
|
||||||
|
self.assertNotEqual(result.exit_code, 0)
|
||||||
|
self.assertIn('not found in changelog', result.stdout)
|
||||||
|
|
||||||
|
def test_tag_deletion(self):
|
||||||
|
runner = CliRunner()
|
||||||
|
location = 'CHANGELOG.md'
|
||||||
|
|
||||||
|
with runner.isolated_filesystem():
|
||||||
|
in_log = yaclog.Changelog(location)
|
||||||
|
in_log.versions = [None, None]
|
||||||
|
in_log.versions = [yaclog.changelog.VersionEntry(), yaclog.changelog.VersionEntry()]
|
||||||
|
|
||||||
|
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'])
|
||||||
|
self.assertNotEqual(result.exit_code, 0)
|
||||||
|
self.assertIn('not found in changelog', result.stdout)
|
||||||
|
|
||||||
|
result = runner.invoke(cli, ['tag', '-d', 'tag3', '0.9.0'])
|
||||||
|
self.assertNotEqual(result.exit_code, 0)
|
||||||
|
self.assertIn('not found in version', result.stdout)
|
||||||
|
|
||||||
|
result = runner.invoke(cli, ['tag', '-d', 'tag1'])
|
||||||
|
self.assertNotIn('not found in version', result.stdout)
|
||||||
|
self.assertEqual(result.exit_code, 0)
|
||||||
|
|
||||||
|
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'])
|
||||||
|
self.assertNotIn('not found in version', result.stdout)
|
||||||
|
self.assertEqual(result.exit_code, 0)
|
||||||
|
|
||||||
|
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):
|
||||||
|
runner = CliRunner()
|
||||||
|
location = 'CHANGELOG.md'
|
||||||
|
|
||||||
|
with runner.isolated_filesystem():
|
||||||
|
runner.invoke(cli, ['init']) # create the changelog
|
||||||
|
runner.invoke(cli, ['entry', '-b', 'entry number 1'])
|
||||||
|
result = runner.invoke(cli, ['release', '--version', '1.0.0'])
|
||||||
|
|
||||||
|
self.assertEqual(yaclog.read(location).versions[0].name, '1.0.0')
|
||||||
|
self.assertTrue('Unreleased' in result.stdout)
|
||||||
|
self.assertTrue('1.0.0' in result.stdout)
|
||||||
|
|
||||||
|
runner.invoke(cli, ['entry', '-b', 'entry number 2'])
|
||||||
|
result = runner.invoke(cli, ['release', '-p'])
|
||||||
|
|
||||||
|
self.assertEqual(yaclog.read(location).versions[0].name, '1.0.1')
|
||||||
|
self.assertTrue('Unreleased' in result.stdout)
|
||||||
|
self.assertTrue('1.0.1' in result.stdout)
|
||||||
|
|
||||||
|
runner.invoke(cli, ['entry', '-b', 'entry number 3'])
|
||||||
|
result = runner.invoke(cli, ['release', '-m'])
|
||||||
|
|
||||||
|
self.assertEqual(yaclog.read(location).versions[0].name, '1.1.0')
|
||||||
|
self.assertTrue('Unreleased' in result.stdout)
|
||||||
|
self.assertTrue('1.1.0' in result.stdout)
|
||||||
|
|
||||||
|
runner.invoke(cli, ['entry', '-b', 'entry number 4'])
|
||||||
|
result = runner.invoke(cli, ['release', '-M'])
|
||||||
|
|
||||||
|
self.assertEqual(yaclog.read(location).versions[0].name, '2.0.0')
|
||||||
|
self.assertTrue('Unreleased' in result.stdout)
|
||||||
|
self.assertTrue('2.0.0' in result.stdout)
|
||||||
|
|
||||||
|
def test_commit(self):
|
||||||
|
runner = CliRunner()
|
||||||
|
|
||||||
|
with runner.isolated_filesystem():
|
||||||
|
repo = git.Repo.init(os.path.join(os.curdir, 'testing'))
|
||||||
|
os.chdir('testing')
|
||||||
|
repo.index.commit('initial commit')
|
||||||
|
|
||||||
|
runner.invoke(cli, ['init']) # create the changelog
|
||||||
|
runner.invoke(cli, ['entry', '-b', 'entry number 1'])
|
||||||
|
result = runner.invoke(cli, ['release', '--version', '1.0.0', '-c'], input='y\n')
|
||||||
|
|
||||||
|
self.assertIn('Created commit', result.stdout)
|
||||||
|
self.assertIn('Created tag', result.stdout)
|
||||||
|
self.assertIn(repo.head.commit.hexsha[0:7], result.stdout)
|
||||||
|
self.assertEqual(repo.tags[0].name, '1.0.0')
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
Loading…
Reference in New Issue
Block a user