Exemple #1
0
def test_script_raise_commit(capsys, db, scripts):
    """ test rollback when script raises """
    script = scripts / "with_commit_raise.py"
    with pytest.raises(RuntimeError) as excinfo:
        shell(**dict(params, database=db, script=script))
    assert "scripterror" in str(excinfo.value)
    assert has_newadmin(db)
Exemple #2
0
def test_script_with_database(capsys, db, scripts):
    """ Test access to local variables & environment, and if shell commits """
    script = scripts / "with_database.py"
    shell(**dict(params, script=script, database=db))
    captured = capsys.readouterr()
    assert "script - output:" in captured.out
    assert has_newadmin(db)
Exemple #3
0
def test_stdin(capsys, mocker):
    mock = mocker.patch("dodoo_shell.sys.stdin")
    mock.read.return_value = "print('hello world')"
    shell(**dict(params))
    assert mock.read.call_count == 1
    captured = capsys.readouterr()
    assert "hello world" in captured.out
Exemple #4
0
def test_dry_run_rollback(capsys, db, scripts):
    """ Test rollback on dry run """
    script = scripts / "with_database.py"
    shell(**dict(params, dry_run=True, database=db, script=script))
    captured = capsys.readouterr()
    assert "script - output:" in captured.out
    assert "admin->newadmin" in captured.out
    assert has_admin(db)
Exemple #5
0
def test_interactive_with_manual_commit(capsys, db, scripts, mocker):
    """ test rollback in interactive mode without manual commit """
    mock = mocker.patch("dodoo_shell._from_stdin")
    script = scripts / "with_commit.py"
    shell(**dict(params, interactive=True, database=db, script=script))
    assert mock.call_count == 1
    captured = capsys.readouterr()
    assert "script - output:" in captured.out
    assert "admin->newadmin" in captured.out
    assert has_newadmin(db)
Exemple #6
0
def test_validation_logs(caplog, mocker):
    """ Test validation logs errors as expected """
    mocker.patch("dodoo_shell._from_stdin")
    caplog.set_level(logging.ERROR, logger="dodoo_shell.__init__")
    shell(**dict(params, dry_run=True))
    assert len(caplog.records) == 1
    assert f"parameter(s) dry_run require 'database' parameter." in caplog.text
    caplog.clear()
    shell(**dict(params, uid=5))
    assert len(caplog.records) == 1
    assert f"parameter(s) uid require 'database' parameter." in caplog.text
Exemple #7
0
def test_script_with_database_exception(scripts, main_loaded):
    """ Test script failure on access of unavailable variable """
    script = scripts / "with_database.py"
    with pytest.raises(NameError):
        shell(**dict(params, script=script))
Exemple #8
0
def test_script_without_database(capsys, scripts, main_loaded):
    """ Test access to non-db local variable """
    script = scripts / "without_database.py"
    shell(**dict(params, script=script))
    captured = capsys.readouterr()
    assert "script - output:" in captured.out
Exemple #9
0
def test_script_with_args(capsys, scripts):
    script = scripts / "with_args.py"
    shell(**dict(params, script=script, script_args=["hello world"]))
    captured = capsys.readouterr()
    assert captured.out == "hello world\n"
Exemple #10
0
def test_without_script(mocker):
    mock = mocker.patch("dodoo_shell._from_stdin")
    shell(**dict(params))
    assert mock.call_count == 1
Exemple #11
0
def test_console_with_preferred_shell(capsys, mocker):
    _isatty = mocker.patch("dodoo_shell.console._isatty")
    _isatty.return_value = True
    mock = mocker.patch("dodoo_shell.console.PatchedShell.interact")
    shell(**dict(params, shell_interface="ipython"))
    mock.assert_called_once_with({"odoo": None}, preferred_shell="ipython")
Exemple #12
0
def test_rollback_in_script(capsys, db, scripts):
    """ Test script and environment rollback can live together """
    script = scripts / "with_rollback.py"
    shell(**dict(params, dry_run=True, database=db, script=script))
    captured = capsys.readouterr()
    assert "script - output:" in captured.out
Exemple #13
0
def test_dry_run_exception(db, scripts):
    """ Test exception if script unintendedly commits on dry run """
    script = scripts / "with_commit.py"
    with pytest.raises(ScriptCommitsDuringDryRunError):
        shell(**dict(params, dry_run=True, database=db, script=script))