Skip to content

Commit

Permalink
tests: fix test_project.py on Windows
Browse files Browse the repository at this point in the history
This file is giving false negatives on Windows. To fix:

- test_manifest_freeze: expect (and escape) Windows paths
- test_forall: echo may be available in cmd.exe, but single-quoted
  strings sure aren't
- test_extension_command_*: handle newlines portably

Signed-off-by: Marti Bolivar <marti.bolivar@nordicsemi.no>
  • Loading branch information
mbolivar-nordic authored and carlescufi committed May 20, 2019
1 parent 624880e commit c724ee6
Showing 1 changed file with 24 additions and 22 deletions.
46 changes: 24 additions & 22 deletions tests/test_project.py
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,7 @@ def test_manifest_freeze(west_update_tmpdir):
# match project order as specified in our manifest, that all
# revisions are full 40-character SHAs, and there isn't any random
# YAML tag crap.
kconfig_rel = os.path.join('subdir', 'Kconfiglib')
expected_res = ['^manifest:$',
'^ defaults:$',
'^ remote: test-local$',
Expand All @@ -101,7 +102,7 @@ def test_manifest_freeze(west_update_tmpdir):
'^ - name: Kconfiglib$',
'^ remote: test-local$',
'^ revision: [a-f0-9]{40}$',
'^ path: subdir/Kconfiglib$',
'^ path: {}$'.format(re.escape(kconfig_rel)),
'^ - name: net-tools$',
'^ remote: test-local$',
'^ revision: [a-f0-9]{40}$',
Expand Down Expand Up @@ -151,15 +152,15 @@ def test_forall(west_init_tmpdir):

# 'forall' with no projects cloned shouldn't fail

cmd("forall -c 'echo *'")
cmd('forall -c "echo *"')

# Neither should it fail after cloning one or both projects

cmd('update net-tools')
cmd("forall -c 'echo *'")
cmd('forall -c "echo *"')

cmd('update Kconfiglib')
cmd("forall -c 'echo *'")
cmd('forall -c "echo *"')


def test_update_projects(west_init_tmpdir):
Expand Down Expand Up @@ -294,7 +295,7 @@ def test_extension_command_execution(west_init_tmpdir):
cmd('update')

actual = cmd('test')
assert actual == 'Testing test command 1\n'
assert actual.rstrip() == 'Testing test command 1'


def test_extension_command_multiproject(repos_tmpdir):
Expand Down Expand Up @@ -360,22 +361,22 @@ def do_run(self, args, ignored):
config.read_config()
cmd('update')

help_text = cmd('-h')
expected = textwrap.dedent('''\
commands from project at "subdir/Kconfiglib":
kconfigtest: (no help provided; try "west kconfigtest -h")
commands from project at "net-tools":
test: test-help
''')

assert expected in help_text
# The newline shenanigans are for Windows.
help_text = '\n'.join(cmd('-h').splitlines())
expected = '\n'.join([
'commands from project at "{}":'.format(os.path.join('subdir',
'Kconfiglib')),
' kconfigtest: (no help provided; try "west kconfigtest -h")', # noqa: E501
'',
'commands from project at "net-tools":',
' test: test-help'])
assert expected in help_text, help_text

actual = cmd('test')
assert actual == 'Testing test command 1\n'
assert actual.rstrip() == 'Testing test command 1'

actual = cmd('kconfigtest')
assert actual == 'Testing kconfig test\n'
assert actual.rstrip() == 'Testing kconfig test'


def test_extension_command_duplicate(repos_tmpdir):
Expand Down Expand Up @@ -440,12 +441,13 @@ def do_run(self, args, ignored):
config.read_config()
cmd('update')

actual = cmd('test', stderr=subprocess.STDOUT)
warning = 'WARNING: ignoring project net-tools extension command "test";'\
' command "test" already defined as extension command\n'
command_out = 'Testing kconfig test command\n'
actual = cmd('test', stderr=subprocess.STDOUT).splitlines()
expected = [
'WARNING: ignoring project net-tools extension command "test"; command "test" already defined as extension command', # noqa: E501
'Testing kconfig test command',
]

assert actual == warning + command_out
assert actual == expected


#
Expand Down

0 comments on commit c724ee6

Please sign in to comment.