File: test_oracle.py

package info (click to toggle)
python-django 2%3A2.2.28-1~deb11u2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 52,468 kB
  • sloc: python: 235,755; javascript: 19,226; xml: 201; makefile: 175; sh: 43
file content (33 lines) | stat: -rw-r--r-- 1,179 bytes parent folder | download
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
from unittest import mock, skipUnless

from django.db import connection
from django.db.backends.oracle.client import DatabaseClient
from django.test import SimpleTestCase


@skipUnless(connection.vendor == 'oracle', 'Oracle tests')
class OracleDbshellTests(SimpleTestCase):
    def _run_dbshell(self, rlwrap=False):
        """Run runshell command and capture its arguments."""
        def _mock_subprocess_call(*args):
            self.subprocess_args = tuple(*args)
            return 0

        client = DatabaseClient(connection)
        self.subprocess_args = None
        with mock.patch('subprocess.call', new=_mock_subprocess_call):
            with mock.patch('shutil.which', return_value='/usr/bin/rlwrap' if rlwrap else None):
                client.runshell()
        return self.subprocess_args

    def test_without_rlwrap(self):
        self.assertEqual(
            self._run_dbshell(rlwrap=False),
            ('sqlplus', '-L', connection._connect_string()),
        )

    def test_with_rlwrap(self):
        self.assertEqual(
            self._run_dbshell(rlwrap=True),
            ('/usr/bin/rlwrap', 'sqlplus', '-L', connection._connect_string()),
        )