1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
|
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
Test command "open-library" (basic parser tests)
"""
HELP_TEXT = """\
Usage: {executable} [options] open-library [command_options] library
LibrePCB Command Line Interface
Options:
-h, --help Print this message.
-V, --version Displays version information.
-v, --verbose Verbose output.
--all Perform the selected action(s) on all elements contained in
the opened library.
--check Run the library element check, print all non-approved messages
and report failure (exit code = 1) if there are non-approved
messages.
--minify-step Minify the STEP models of all packages. Only works in
conjunction with '--all'. Pass '--save' to write the minified
files to disk.
--save Save library (and contained elements if '--all' is given)
before closing them (useful to upgrade file format).
--strict Fail if the opened files are not strictly canonical, i.e.
there would be changes when saving the library elements.
Arguments:
open-library Open a library to execute library-related tasks.
library Path to library directory (*.lplib).
"""
ERROR_TEXT = """\
{error}
Usage: {executable} [options] open-library [command_options] library
Help: {executable} open-library --help
"""
def test_help(cli):
code, stdout, stderr = cli.run('open-library', '--help')
assert stderr == ''
assert stdout == HELP_TEXT.format(executable=cli.executable)
assert code == 0
def test_no_arguments(cli):
code, stdout, stderr = cli.run('open-library')
assert stderr == ERROR_TEXT.format(
executable=cli.executable,
error="Missing arguments: library",
)
assert stdout == ''
assert code == 1
def test_invalid_argument(cli):
code, stdout, stderr = cli.run('open-library', '--invalid-argument')
assert stderr == ERROR_TEXT.format(
executable=cli.executable,
error="Unknown option 'invalid-argument'.",
)
assert stdout == ''
assert code == 1
|