should be it
This commit is contained in:
65
external/duckdb/tools/shell/tests/test_safe_mode.py
vendored
Normal file
65
external/duckdb/tools/shell/tests/test_safe_mode.py
vendored
Normal file
@@ -0,0 +1,65 @@
|
||||
# fmt: off
|
||||
|
||||
import pytest
|
||||
import subprocess
|
||||
import sys
|
||||
from typing import List
|
||||
from conftest import ShellTest
|
||||
from tools.shell.tests.conftest import random_filepath
|
||||
|
||||
|
||||
@pytest.mark.parametrize("command", [".sh ls", ".cd ..", ".log file", ".import file.csv tbl", ".open new_file", ".output out", ".once out", ".excel out", ".read myfile.sql"])
|
||||
def test_safe_mode_command(shell, command):
|
||||
test = (
|
||||
ShellTest(shell, ['-safe'])
|
||||
.statement(command)
|
||||
)
|
||||
result = test.run()
|
||||
result.check_stderr('cannot be used in -safe mode')
|
||||
|
||||
|
||||
@pytest.mark.parametrize("param", [(".sh ls", 'cannot be used in -safe mode'), ("INSTALL extension", "Permission Error")])
|
||||
def test_safe_mode_dot_command(shell, param):
|
||||
command = param[0]
|
||||
expected_error = param[1]
|
||||
test = (
|
||||
ShellTest(shell)
|
||||
.statement('.safe_mode')
|
||||
.statement(command)
|
||||
)
|
||||
result = test.run()
|
||||
result.check_stderr(expected_error)
|
||||
|
||||
def test_safe_mode_database_basic(shell, random_filepath):
|
||||
test = (
|
||||
ShellTest(shell, [random_filepath, '-safe'])
|
||||
.statement('CREATE TABLE integers(i INT)')
|
||||
.statement('INSERT INTO integers VALUES (1), (2), (3)')
|
||||
.statement('SELECT SUM(i) FROM integers')
|
||||
)
|
||||
result = test.run()
|
||||
result.check_stdout("6")
|
||||
|
||||
@pytest.mark.parametrize("command", [".sh ls", ".cd ..", ".log file", ".import file.csv tbl", ".open new_file", ".output out", ".once out", ".excel out", ".read myfile.sql"])
|
||||
@pytest.mark.parametrize("persistent", [False, True])
|
||||
def test_safe_mode_database_commands(shell, random_filepath, command, persistent):
|
||||
arguments = ['-safe'] if not persistent else [random_filepath, '-safe']
|
||||
test = (
|
||||
ShellTest(shell, arguments)
|
||||
.statement(command)
|
||||
)
|
||||
result = test.run()
|
||||
result.check_stderr('cannot be used in -safe mode')
|
||||
|
||||
@pytest.mark.parametrize("sql", ["COPY (SELECT 42) TO 'test.csv'", "LOAD spatial", "INSTALL spatial", "ATTACH 'file.db' AS file"])
|
||||
@pytest.mark.parametrize("persistent", [False, True])
|
||||
def test_safe_mode_query(shell, random_filepath, sql, persistent):
|
||||
arguments = ['-safe'] if not persistent else [random_filepath, '-safe']
|
||||
test = (
|
||||
ShellTest(shell, arguments)
|
||||
.statement(sql)
|
||||
)
|
||||
result = test.run()
|
||||
result.check_stderr('disabled')
|
||||
|
||||
# fmt: on
|
||||
Reference in New Issue
Block a user