mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2024-11-27 12:14:10 +08:00
a4845e9c43
If we don't do this, we end up with email-alike strings to be turned into mailto links. This is not what we want. Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/25712>
206 lines
5.8 KiB
Python
206 lines
5.8 KiB
Python
# Copyright © 2019,2021 Intel Corporation
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
# in the Software without restriction, including without limitation the rights
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
# furnished to do so, subject to the following conditions:
|
|
|
|
# The above copyright notice and this permission notice shall be included in
|
|
# all copies or substantial portions of the Software.
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
# SOFTWARE.
|
|
|
|
import sys
|
|
import textwrap
|
|
import typing
|
|
|
|
import pytest
|
|
|
|
# AsyncMock is new in 3.8, so if we're using an older version we need the
|
|
# backported version of mock
|
|
if sys.version_info >= (3, 8):
|
|
from unittest import mock
|
|
else:
|
|
import mock
|
|
|
|
from .gen_release_notes import *
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
'current, is_point, expected',
|
|
[
|
|
('19.2.0', True, '19.2.1'),
|
|
('19.3.6', True, '19.3.7'),
|
|
('20.0.0-rc4', False, '20.0.0'),
|
|
])
|
|
def test_next_version(current: str, is_point: bool, expected: str) -> None:
|
|
assert calculate_next_version(current, is_point) == expected
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
'current, is_point, expected',
|
|
[
|
|
('19.3.6', True, '19.3.6'),
|
|
('20.0.0-rc4', False, '19.3.0'),
|
|
])
|
|
def test_previous_version(current: str, is_point: bool, expected: str) -> None:
|
|
assert calculate_previous_version(current, is_point) == expected
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_get_shortlog():
|
|
# Certainly not perfect, but it's something
|
|
version = '19.2.0'
|
|
out = await get_shortlog(version)
|
|
assert out
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_gather_commits():
|
|
# Certainly not perfect, but it's something
|
|
version = '19.2.0'
|
|
out = await gather_commits(version)
|
|
assert out
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
@pytest.mark.parametrize(
|
|
'content, bugs',
|
|
[
|
|
# It is important to have the title on a new line, as
|
|
# textwrap.dedent won't work otherwise.
|
|
|
|
# Test the `Closes: #N` syntax
|
|
(
|
|
'''\
|
|
A commit
|
|
|
|
It has a message in it
|
|
|
|
Closes: #1
|
|
''',
|
|
['1'],
|
|
),
|
|
|
|
# Test the Full url
|
|
(
|
|
'''\
|
|
A commit with no body
|
|
|
|
Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/3456
|
|
''',
|
|
['3456'],
|
|
),
|
|
|
|
# Test projects that are not mesa
|
|
(
|
|
'''\
|
|
A commit for libdrm
|
|
|
|
Closes: https://gitlab.freedesktop.org/mesa/drm/-/3456
|
|
''',
|
|
[],
|
|
),
|
|
(
|
|
'''\
|
|
A commit for for something else completely
|
|
|
|
Closes: https://github.com/Organization/project/1234
|
|
''',
|
|
[],
|
|
),
|
|
|
|
# Test multiple issues on one line
|
|
(
|
|
'''\
|
|
Fix many bugs
|
|
|
|
Closes: #1, #2
|
|
''',
|
|
['1', '2'],
|
|
),
|
|
|
|
# Test multiple closes
|
|
(
|
|
'''\
|
|
Fix many bugs
|
|
|
|
Closes: #1
|
|
Closes: #2
|
|
''',
|
|
['1', '2'],
|
|
),
|
|
(
|
|
'''\
|
|
With long form
|
|
|
|
Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/3456
|
|
Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/3457
|
|
Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/3458
|
|
''',
|
|
['3456', '3457', '3458'],
|
|
),
|
|
(
|
|
'''\
|
|
Without /-/
|
|
|
|
Closes: https://gitlab.freedesktop.org/mesa/mesa/issues/36
|
|
''',
|
|
['36'],
|
|
),
|
|
(
|
|
'''\
|
|
Ignore merge_requests
|
|
|
|
Closes: https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20241
|
|
''',
|
|
[],
|
|
),
|
|
(
|
|
'''\
|
|
Parse "Fixes:" tag too
|
|
|
|
Fixes: https://gitlab.freedesktop.org/mesa/mesa/issues/36
|
|
Fixes: 142565a3bc2
|
|
Fixes: 142565a3bc2 ("docs: do something very useful")
|
|
Fixes: 142565a3bc2 ("docs: fix #1234, have a comma")
|
|
Fixes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/37
|
|
''',
|
|
['36', '37'],
|
|
),
|
|
(
|
|
'''\
|
|
Parse Fixes/Closes in weird cases
|
|
|
|
fixes: https://gitlab.freedesktop.org/mesa/mesa/issues/36
|
|
fiXES: https://gitlab.freedesktop.org/mesa/mesa/issues/37
|
|
closes: https://gitlab.freedesktop.org/mesa/mesa/issues/38
|
|
cloSES: https://gitlab.freedesktop.org/mesa/mesa/issues/39
|
|
''',
|
|
['36', '37', '38', '39'],
|
|
),
|
|
])
|
|
async def test_parse_issues(content: str, bugs: typing.List[str]) -> None:
|
|
mock_com = mock.AsyncMock(return_value=(textwrap.dedent(content).encode(), ''))
|
|
mock_p = mock.Mock()
|
|
mock_p.communicate = mock_com
|
|
mock_exec = mock.AsyncMock(return_value=mock_p)
|
|
|
|
with mock.patch('bin.gen_release_notes.asyncio.create_subprocess_exec', mock_exec), \
|
|
mock.patch('bin.gen_release_notes.gather_commits', mock.AsyncMock(return_value='sha\n')):
|
|
ids = await parse_issues('1234 not used')
|
|
assert set(ids) == set(bugs)
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_rst_escape():
|
|
out = inliner.quoteInline('foo@bar')
|
|
assert out == 'foo\@bar'
|