{
  "RepoName": "https://github.com/piskvorky/sqlitedict.git",
  "CommitSHA": "96e81621fd6ab094efdd86e70fd57efe9d40ca12",
  "Time": "",
  "Difficulty": "Medium",
  "Type": "type mismatch",
  "BuggyCode": [
    {
      "path": "piskvorky_sqlitedict/sqlitedict.py",
      "content": "#!/usr/bin/env python\n# -*- coding: utf-8 -*-\n#\n# This code is distributed under the terms and conditions\n# from the Apache License, Version 2.0\n#\n# http://opensource.org/licenses/apache2.0.php\n#\n# This code was inspired by:\n#  * http://code.activestate.com/recipes/576638-draft-for-an-sqlite3-based-dbm/\n#  * http://code.activestate.com/recipes/526618/\n\n\"\"\"\nA lightweight wrapper around Python's sqlite3 database, with a dict-like interface\nand multi-thread access support::\n\n>>> mydict = SqliteDict('some.db', autocommit=True) # the mapping will be persisted to file `some.db`\n>>> mydict['some_key'] = any_picklable_object\n>>> print mydict['some_key']\n>>> print len(mydict) # etc... all dict functions work\n\nPickle is used internally to serialize the values. Keys are strings.\n\nIf you don't use autocommit (default is no autocommit for performance), then\ndon't forget to call `mydict.commit()` when done with a transaction.\n\n\"\"\"\n\nimport sqlite3\nimport os\nimport sys\nimport tempfile\nimport threading\nimport logging\nimport traceback\nfrom base64 import b64decode, b64encode\nimport weakref\n\n__version__ = '2.1.0'\n\n\ndef reraise(tp, value, tb=None):\n    if value is None:\n        value = tp()\n    if value.__traceback__ is not tb:\n        raise value.with_traceback(tb)\n    raise value\n\n\ntry:\n    from cPickle import dumps, loads, HIGHEST_PROTOCOL as PICKLE_PROTOCOL\nexcept ImportError:\n    from pickle import dumps, loads, HIGHEST_PROTOCOL as PICKLE_PROTOCOL\n\n# some Python 3 vs 2 imports\ntry:\n    from collections import UserDict as DictClass\nexcept ImportError:\n    from UserDict import DictMixin as DictClass\n\ntry:\n    from queue import Queue\nexcept ImportError:\n    from Queue import Queue\n\n\nlogger = logging.getLogger(__name__)\n\n#\n# There's a thread that holds the actual SQL connection (SqliteMultithread).\n# We communicate with this thread via queues (request and responses).\n# The requests can either be SQL commands or one of the \"special\" commands\n# below:\n#\n# _REQUEST_CLOSE: request that the SQL connection be closed\n# _REQUEST_COMMIT: request that any changes be committed to the DB\n#\n# Responses are either SQL records (e.g. results of a SELECT) or the magic\n# _RESPONSE_NO_MORE command, which indicates nothing else will ever be written\n# to the response queue.\n#\n_REQUEST_CLOSE = '--close--'\n_REQUEST_COMMIT = '--commit--'\n_RESPONSE_NO_MORE = '--no more--'\n\n#\n# We work with weak references for better memory efficiency.\n# Dereferencing, checking the referent queue still exists, and putting to it\n# is boring and repetitive, so we have a _put function to handle it for us.\n#\n_PUT_OK, _PUT_REFERENT_DESTROYED, _PUT_NOOP = 0, 1, 2\n\n\ndef _put(queue_reference, item):\n    if queue_reference is not None:\n        queue = queue_reference()\n        if queue is None:\n            #\n            # We got a reference to a queue, but that queue no longer exists\n            #\n            retval = _PUT_REFERENT_DESTROYED\n        else:\n            queue.put(item)\n            retval = _PUT_OK\n\n        del queue\n        return retval\n\n    #\n    # We didn't get a reference to a queue, so do nothing (no-op).\n    #\n    return _PUT_NOOP\n\n\ndef open(*args, **kwargs):\n    \"\"\"See documentation of the SqliteDict class.\"\"\"\n    return SqliteDict(*args, **kwargs)\n\n\ndef encode(obj):\n    \"\"\"Serialize an object using pickle to a binary format accepted by SQLite.\"\"\"\n    return sqlite3.Binary(dumps(obj, protocol=PICKLE_PROTOCOL))\n\n\ndef decode(obj):\n    \"\"\"Deserialize objects retrieved from SQLite.\"\"\"\n    return loads(bytes(obj))\n\n\ndef encode_key(key):\n    \"\"\"Serialize a key using pickle + base64 encoding to text accepted by SQLite.\"\"\"\n    return b64encode(dumps(key, protocol=PICKLE_PROTOCOL)).decode(\"ascii\")\n\n\ndef decode_key(key):\n    \"\"\"Deserialize a key retrieved from SQLite.\"\"\"\n    return loads(b64decode(key.encode(\"ascii\")))\n\n\ndef identity(obj):\n    \"\"\"Identity f(x) = x function for encoding/decoding.\"\"\"\n    return obj\n\n\nclass SqliteDict(DictClass):\n    VALID_FLAGS = ['c', 'r', 'w', 'n']\n\n    def __init__(self, filename=None, tablename='unnamed', flag='c',\n                 autocommit=False, journal_mode=\"DELETE\", encode=encode,\n                 decode=decode, encode_key=identity, decode_key=identity,\n                 timeout=5, outer_stack=True):\n        \"\"\"\n        Initialize a thread-safe sqlite-backed dictionary. The dictionary will\n        be a table `tablename` in database file `filename`. A single file (=database)\n        may contain multiple tables.\n\n        If no `filename` is given, a random file in temp will be used (and deleted\n        from temp once the dict is closed/deleted).\n\n        If you enable `autocommit`, changes will be committed after each operation\n        (more inefficient but safer). Otherwise, changes are committed on `self.commit()`,\n        `self.clear()` and `self.close()`.\n\n        Set `journal_mode` to 'OFF' if you're experiencing sqlite I/O problems\n        or if you need performance and don't care about crash-consistency.\n\n        Set `outer_stack` to False to disable the output of the outer exception\n        to the error logs.  This may improve the efficiency of sqlitedict\n        operation at the expense of a detailed exception trace.\n\n        The `flag` parameter. Exactly one of:\n          'c': default mode, open for read/write, creating the db/table if necessary.\n          'w': open for r/w, but drop `tablename` contents first (start with empty table)\n          'r': open as read-only\n          'n': create a new database (erasing any existing tables, not just `tablename`!).\n\n        The `encode` and `decode` parameters are used to customize how the values\n        are serialized and deserialized.\n        The `encode` parameter must be a function that takes a single Python\n        object and returns a serialized representation.\n        The `decode` function must be a function that takes the serialized\n        representation produced by `encode` and returns a deserialized Python\n        object.\n        The default is to use pickle.\n\n        The `timeout` defines the maximum time (in seconds) to wait for initial Thread startup.\n\n        \"\"\"\n        self.in_temp = filename is None\n        if self.in_temp:\n            fd, filename = tempfile.mkstemp(prefix='sqldict')\n            os.close(fd)\n\n        if flag not in SqliteDict.VALID_FLAGS:\n            raise RuntimeError(\"Unrecognized flag: %s\" % flag)\n        self.flag = flag\n\n        if flag == 'n':\n            if os.path.exists(filename):\n                os.remove(filename)\n\n        dirname = os.path.dirname(filename)\n        if dirname:\n            if not os.path.exists(dirname):\n                raise RuntimeError('Error! The directory does not exist, %s' % dirname)\n\n        self.filename = filename\n\n        # Use standard SQL escaping of double quote characters in identifiers, by doubling them.\n        # See https://github.com/RaRe-Technologies/sqlitedict/pull/113\n        self.tablename = tablename.replace('\"', '\"\"')\n\n        self.autocommit = autocommit\n        self.journal_mode = journal_mode\n        self.encode = encode\n        self.decode = decode\n        self.encode_key = encode_key\n        self.decode_key = decode_key\n        self._outer_stack = outer_stack\n\n        logger.debug(\"opening Sqlite table %r in %r\" % (tablename, filename))\n        self.conn = self._new_conn()\n        if self.flag == 'r':\n            if self.tablename not in SqliteDict.get_tablenames(self.filename):\n                msg = 'Refusing to create a new table \"%s\" in read-only DB mode' % tablename\n                raise RuntimeError(msg)\n        else:\n            MAKE_TABLE = 'CREATE TABLE IF NOT EXISTS \"%s\" (key TEXT PRIMARY KEY, value BLOB)' % self.tablename\n            self.conn.execute(MAKE_TABLE)\n            self.conn.commit()\n        if flag == 'w':\n            self.clear()\n\n    def _new_conn(self):\n        return SqliteMultithread(\n            self.filename,\n            autocommit=self.autocommit,\n            journal_mode=self.journal_mode,\n            outer_stack=self._outer_stack,\n        )\n\n    def __enter__(self):\n        if not hasattr(self, 'conn') or self.conn is None:\n            self.conn = self._new_conn()\n        return self\n\n    def __exit__(self, *exc_info):\n        self.close()\n\n    def __str__(self):\n        return \"SqliteDict(%s)\" % (self.filename)\n\n    def __repr__(self):\n        return str(self)  # no need of something complex\n\n    def __len__(self):\n        # `select count (*)` is super slow in sqlite (does a linear scan!!)\n        # As a result, len() is very slow too once the table size grows beyond trivial.\n        # We could keep the total count of rows ourselves, by means of triggers,\n        # but that seems too complicated and would slow down normal operation\n        # (insert/delete etc).\n        GET_LEN = 'SELECT COUNT(*) FROM \"%s\"' % self.tablename\n        rows = self.conn.select_one(GET_LEN)[0]\n        return rows if rows is not None else 0\n\n    def __bool__(self):\n        # No elements is False, otherwise True\n        GET_MAX = 'SELECT MAX(ROWID) FROM \"%s\"' % self.tablename\n        m = self.conn.select_one(GET_MAX)[0]\n        # Explicit better than implicit and bla bla\n        return True if m is not None else False\n\n    def iterkeys(self):\n        GET_KEYS = 'SELECT key FROM \"%s\" ORDER BY rowid' % self.tablename\n        for key in self.conn.select(GET_KEYS):\n            yield self.decode_key(key[0])\n\n    def itervalues(self):\n        GET_VALUES = 'SELECT value FROM \"%s\" ORDER BY rowid' % self.tablename\n        for value in self.conn.select(GET_VALUES):\n            yield self.decode(value[0])\n\n    def iteritems(self):\n        GET_ITEMS = 'SELECT key, value FROM \"%s\" ORDER BY rowid' % self.tablename\n        for key, value in self.conn.select(GET_ITEMS):\n            yield self.decode_key(key), self.decode(value)\n\n    def keys(self):\n        return self.iterkeys()\n\n    def values(self):\n        return self.itervalues()\n\n    def items(self):\n        return self.iteritems()\n\n    def __contains__(self, key):\n        HAS_ITEM = 'SELECT 1 FROM \"%s\" WHERE key = ?' % self.tablename\n        return self.conn.select_one(HAS_ITEM, (self.encode_key(key),)) is not None\n\n    def __getitem__(self, key):\n        GET_ITEM = 'SELECT value FROM \"%s\" WHERE key = ?' % self.tablename\n        item = self.conn.select_one(GET_ITEM, (self.encode_key(key),))\n        if item is None:\n            raise KeyError(key)\n        return self.decode(item[0])\n\n    def __setitem__(self, key, value):\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to write to read-only SqliteDict')\n\n        ADD_ITEM = 'REPLACE INTO \"%s\" (key, value) VALUES (?,?)' % self.tablename\n        self.conn.execute(ADD_ITEM, (self.encode_key(key), self.encode(value)))\n        if self.autocommit:\n            self.commit()\n\n    def __delitem__(self, key):\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to delete from read-only SqliteDict')\n\n        if key not in self:\n            raise KeyError(key)\n        DEL_ITEM = 'DELETE FROM \"%s\" WHERE key = ?' % self.tablename\n        self.conn.execute(DEL_ITEM, (self.encode_key(key),))\n        if self.autocommit:\n            self.commit()\n\n    def update(self, items=(), **kwds):\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to update read-only SqliteDict')\n\n        try:\n            items = items.items()\n        except AttributeError:\n            pass\n        items = [(self.encode_key(k), self.encode(v)) for k, v in items]\n\n        UPDATE_ITEMS = 'REPLACE INTO \"%s\" (key, value) VALUES (?, ?)' % self.tablename\n        self.conn.executemany(UPDATE_ITEMS, items)\n        if kwds:\n            self.update(kwds)\n        if self.autocommit:\n            self.commit()\n\n    def __iter__(self):\n        return self.iterkeys()\n\n    def clear(self):\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to clear read-only SqliteDict')\n\n        # avoid VACUUM, as it gives \"OperationalError: database schema has changed\"\n        CLEAR_ALL = 'DELETE FROM \"%s\";' % self.tablename\n        self.conn.commit()\n        self.conn.execute(CLEAR_ALL)\n        self.conn.commit()\n\n    @staticmethod\n    def get_tablenames(filename):\n        \"\"\"get the names of the tables in an sqlite db as a list\"\"\"\n        if not os.path.isfile(filename):\n            raise IOError('file %s does not exist' % (filename))\n        GET_TABLENAMES = 'SELECT name FROM sqlite_master WHERE type=\"table\"'\n        with sqlite3.connect(filename) as conn:\n            cursor = conn.execute(GET_TABLENAMES)\n            res = cursor.fetchall()\n\n        return [name[0] for name in res]\n\n    def commit(self, blocking=True):\n        \"\"\"\n        Persist all data to disk.\n\n        When `blocking` is False, the commit command is queued, but the data is\n        not guaranteed persisted (default implication when autocommit=True).\n        \"\"\"\n        if self.conn is not None:\n            self.conn.commit(blocking)\n    sync = commit\n\n    def close(self, do_log=True, force=False):\n        if do_log:\n            logger.debug(\"closing %s\" % self)\n        if hasattr(self, 'conn') and self.conn is not None:\n            if self.conn.autocommit and not force:\n                # typically calls to commit are non-blocking when autocommit is\n                # used.  However, we need to block on close() to ensure any\n                # awaiting exceptions are handled and that all data is\n                # persisted to disk before returning.\n                self.conn.commit(blocking=True)\n            self.conn.close(force=force)\n            self.conn = None\n        if self.in_temp:\n            try:\n                os.remove(self.filename)\n            except Exception:\n                pass\n\n    def terminate(self):\n        \"\"\"Delete the underlying database file. Use with care.\"\"\"\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to terminate read-only SqliteDict')\n\n        self.close()\n\n        if self.filename == ':memory:':\n            return\n\n        logger.info(\"deleting %s\" % self.filename)\n        try:\n            if os.path.isfile(self.filename):\n                os.remove(self.filename)\n        except (OSError, IOError):\n            logger.exception(\"failed to delete %s\" % (self.filename))\n\n    def __del__(self):\n        # like close(), but assume globals are gone by now (do not log!)\n        try:\n            self.close(do_log=False, force=True)\n        except Exception:\n            # prevent error log flood in case of multiple SqliteDicts\n            # closed after connection lost (exceptions are always ignored\n            # in __del__ method.\n            pass\n\n\nclass SqliteMultithread(threading.Thread):\n    \"\"\"\n    Wrap sqlite connection in a way that allows concurrent requests from multiple threads.\n\n    This is done by internally queueing the requests and processing them sequentially\n    in a separate thread (in the same order they arrived).\n\n    \"\"\"\n    def __init__(self, filename, autocommit, journal_mode, outer_stack=True):\n        super(SqliteMultithread, self).__init__()\n        self.filename = filename\n        self.autocommit = autocommit\n        self.journal_mode = journal_mode\n        # use request queue of unlimited size\n        self.reqs = Queue()\n        self.daemon = True\n        self._outer_stack = outer_stack\n        self.log = logging.getLogger('sqlitedict.SqliteMultithread')\n\n        #\n        # Parts of this object's state get accessed from different threads, so\n        # we use synchronization to avoid race conditions.  For example,\n        # .exception gets set inside the new daemon thread that we spawned, but\n        # gets read from the main thread.  This is particularly important\n        # during initialization: the Thread needs some time to actually start\n        # working, and until this happens, any calls to e.g.\n        # check_raise_error() will prematurely return None, meaning all is\n        # well.  If the that connection happens to fail, we'll never know about\n        # it, and instead wait for a result that never arrives (effectively,\n        # deadlocking).  Locking solves this problem by eliminating the race\n        # condition.\n        #\n        self._lock = threading.Lock()\n        self._lock.acquire()\n        self.exception = None\n\n        self.start()\n\n    def _connect(self):\n        \"\"\"Connect to the underlying database.\n\n        Raises an exception on failure.  Returns the connection and cursor on success.\n        \"\"\"\n        try:\n            if self.autocommit:\n                conn = sqlite3.connect(self.filename, isolation_level=None, check_same_thread=False)\n            else:\n                conn = sqlite3.connect(self.filename, check_same_thread=False)\n        except Exception:\n            self.log.exception(\"Failed to initialize connection for filename: %s\" % self.filename)\n            self.exception = sys.exc_info()\n            raise\n\n        try:\n            conn.execute('PRAGMA journal_mode = %s' % self.journal_mode)\n            conn.text_factory = str\n            cursor = conn.cursor()\n            conn.commit()\n            cursor.execute('PRAGMA synchronous=OFF')\n        except Exception:\n            self.log.exception(\"Failed to execute PRAGMA statements.\")\n            self.exception = sys.exc_info()\n            raise\n\n        return conn, cursor\n\n    def run(self):\n        #\n        # Nb. this is what actually runs inside the new daemon thread.\n        # self._lock is locked at this stage - see the initializer function.\n        #\n        try:\n            conn, cursor = self._connect()\n        finally:\n            self._lock.release()\n\n        res_ref = None\n        while True:\n            #\n            # req: an SQL command or one of the --magic-- commands we use internally\n            # arg: arguments for the command\n            # res_ref: a weak reference to the queue into which responses must be placed\n            # outer_stack: the outer stack, for producing more informative traces in case of error\n            #\n            req, arg, res_ref, outer_stack = self.reqs.get()\n\n            if req == _REQUEST_CLOSE:\n                assert res_ref, ('--close-- without return queue', res_ref)\n                break\n            elif req == _REQUEST_COMMIT:\n                conn.commit()\n                _put(res_ref, _RESPONSE_NO_MORE)\n            else:\n                try:\n                    cursor.execute(req, arg)\n                except Exception:\n                    with self._lock:\n                        self.exception = (e_type, e_value, e_tb) = sys.exc_info()\n\n                    inner_stack = traceback.extract_stack()\n\n                    # An exception occurred in our thread, but we may not\n                    # immediately able to throw it in our calling thread, if it has\n                    # no return `res` queue: log as level ERROR both the inner and\n                    # outer exception immediately.\n                    #\n                    # Any iteration of res.get() or any next call will detect the\n                    # inner exception and re-raise it in the calling Thread; though\n                    # it may be confusing to see an exception for an unrelated\n                    # statement, an ERROR log statement from the 'sqlitedict.*'\n                    # namespace contains the original outer stack location.\n                    self.log.error('Inner exception:')\n                    for item in traceback.format_list(inner_stack):\n                        self.log.error(item)\n                    self.log.error('')  # deliniate traceback & exception w/blank line\n                    for item in traceback.format_exception_only(e_type, e_value):\n                        self.log.error(item)\n\n                    self.log.error('')  # exception & outer stack w/blank line\n\n                    if self._outer_stack:\n                        self.log.error('Outer stack:')\n                        for item in traceback.format_list(outer_stack):\n                            self.log.error(item)\n                        self.log.error('Exception will be re-raised at next call.')\n                    else:\n                        self.log.error(\n                            'Unable to show the outer stack. Pass '\n                            'outer_stack=True when initializing the '\n                            'SqliteDict instance to show the outer stack.'\n                        )\n\n                if res_ref:\n                    for rec in cursor:\n                        if _put(res_ref, rec) == _PUT_REFERENT_DESTROYED:\n                            #\n                            # The queue we are sending responses to got garbage\n                            # collected.  Nobody is listening anymore, so we\n                            # stop sending responses.\n                            #\n                            break\n\n                    _put(res_ref, _RESPONSE_NO_MORE)\n\n                if self.autocommit:\n                    conn.commit()\n\n        self.log.debug('received: %s, send: --no more--', req)\n        conn.close()\n\n        _put(res_ref, _RESPONSE_NO_MORE)\n\n    def check_raise_error(self):\n        \"\"\"\n        Check for and raise exception for any previous sqlite query.\n\n        For the `execute*` family of method calls, such calls are non-blocking and any\n        exception raised in the thread cannot be handled by the calling Thread (usually\n        MainThread).  This method is called on `close`, and prior to any subsequent\n        calls to the `execute*` methods to check for and raise an exception in a\n        previous call to the MainThread.\n        \"\"\"\n        with self._lock:\n            if self.exception:\n                e_type, e_value, e_tb = self.exception\n\n                # clear self.exception, if the caller decides to handle such\n                # exception, we should not repeatedly re-raise it.\n                self.exception = None\n\n                self.log.error('An exception occurred from a previous statement, view '\n                               'the logging namespace \"sqlitedict\" for outer stack.')\n\n                # The third argument to raise is the traceback object, and it is\n                # substituted instead of the current location as the place where\n                # the exception occurred, this is so that when using debuggers such\n                # as `pdb', or simply evaluating the naturally raised traceback, we\n                # retain the original (inner) location of where the exception\n                # occurred.\n                reraise(e_type, e_value, e_tb)\n\n    def execute(self, req, arg=None, res=None):\n        \"\"\"\n        `execute` calls are non-blocking: just queue up the request and return immediately.\n\n        :param req: The request (an SQL command)\n        :param arg: Arguments to the SQL command\n        :param res: A queue in which to place responses as they become available\n        \"\"\"\n        self.check_raise_error()\n        stack = None\n\n        if self._outer_stack:\n            # NOTE: This might be a lot of information to pump into an input\n            # queue, affecting performance.  I've also seen earlier versions of\n            # jython take a severe performance impact for throwing exceptions\n            # so often.\n            stack = traceback.extract_stack()[:-1]\n\n        #\n        # We pass a weak reference to the response queue instead of a regular\n        # reference, because we want the queues to be garbage-collected\n        # more aggressively.\n        #\n        res_ref = None\n        if res:\n            res_ref = weakref.ref(res)\n\n        self.reqs.put((req, arg or tuple(), res_ref, stack))\n\n    def executemany(self, req, items):\n        for item in items:\n            self.execute(req, item)\n        self.check_raise_error()\n\n    def select(self, req, arg=None):\n        \"\"\"\n        Unlike sqlite's native select, this select doesn't handle iteration efficiently.\n\n        The result of `select` starts filling up with values as soon as the\n        request is dequeued, and although you can iterate over the result normally\n        (`for res in self.select(): ...`), the entire result will be in memory.\n        \"\"\"\n        res = Queue()  # results of the select will appear as items in this queue\n        self.execute(req, arg, res)\n        while True:\n            rec = res.get()\n            self.check_raise_error()\n            if rec == _RESPONSE_NO_MORE:\n                break\n            yield rec\n\n    def select_one(self, req, arg=None):\n        \"\"\"Return only the first row of the SELECT, or None if there are no matching rows.\"\"\"\n        try:\n            return next(iter(self.select(req, arg)))\n        except StopIteration:\n            return None\n\n    def commit(self, blocking=True):\n        if blocking:\n            # by default, we await completion of commit() unless\n            # blocking=False.  This ensures any available exceptions for any\n            # previous statement are thrown before returning, and that the\n            # data has actually persisted to disk!\n            self.select_one(_REQUEST_COMMIT)\n        else:\n            # otherwise, we fire and forget as usual.\n            self.execute(_REQUEST_COMMIT)\n\n    def close(self, force=False):\n        if force:\n            # If a SqliteDict is being killed or garbage-collected, then select_one()\n            # could hang forever because run() might already have exited and therefore\n            # can't process the request. Instead, push the close command to the requests\n            # queue directly. If run() is still alive, it will exit gracefully. If not,\n            # then there's nothing we can do anyway.\n            self.reqs.put((_REQUEST_CLOSE, None, weakref.ref(Queue()), None))\n        else:\n            # we abuse 'select' to \"iter\" over a \"--close--\" statement so that we\n            # can confirm the completion of close before joining the thread and\n            # returning (by semaphore '--no more--'\n            self.select_one(_REQUEST_CLOSE)\n            self.join()\n\n\n#\n# This is here for .github/workflows/release.yml\n#\nif __name__ == '__main__':\n    print(__version__)\n"
    },
    {
      "path": "piskvorky_sqlitedict/setup.py",
      "content": "#!/usr/bin/env python\n# -*- coding: utf-8 -*-\n#\n# This code is distributed under the terms and conditions\n# from the Apache License, Version 2.0\n#\n# http://opensource.org/licenses/apache2.0.php\n\n\"\"\"\nRun with:\n\npython ./setup.py install\n\"\"\"\n\nimport os\nimport io\nimport subprocess\n\nimport setuptools.command.develop\nfrom setuptools import setup\n\n\ndef read(fname):\n    path = os.path.join(os.path.dirname(__file__), fname)\n    return io.open(path, encoding='utf8').read()\n\n\nclass SetupDevelop(setuptools.command.develop.develop):\n    \"\"\"Docstring is overwritten.\"\"\"\n\n    def run(self):\n        \"\"\"\n        Prepare environment for development.\n\n        - Ensures 'nose' and 'coverage.py' are installed for testing.\n        - Call super()'s run method.\n        \"\"\"\n        subprocess.check_call(('pip', 'install', 'nose', 'coverage'))\n\n        # Call super() (except develop is an old-style class, so we must call\n        # directly). The effect is that the development egg-link is installed.\n        setuptools.command.develop.develop.run(self)\n\n\nSetupDevelop.__doc__ = setuptools.command.develop.develop.__doc__\n\n\nsetup(\n    name='sqlitedict',\n    version='2.1.0',\n    description='Persistent dict in Python, backed up by sqlite3 and pickle, multithread-safe.',\n    long_description=read('README.rst'),\n\n    py_modules=['sqlitedict'],\n\n    # there is a bug in python2.5, preventing distutils from using any non-ascii characters :(\n    # http://bugs.python.org/issue2562\n    author='Radim Rehurek, Victor R. Escobar, Andrey Usov, Prasanna Swaminathan, Jeff Quast',\n    author_email=\"me@radimrehurek.com\",\n    maintainer='Radim Rehurek',\n    maintainer_email='me@radimrehurek.com',\n\n    url='https://github.com/piskvorky/sqlitedict',\n    download_url='http://pypi.python.org/pypi/sqlitedict',\n\n    keywords='sqlite, persistent dict, multithreaded',\n\n    license='Apache 2.0',\n    platforms='any',\n\n    classifiers=[  # from http://pypi.python.org/pypi?%3Aaction=list_classifiers\n        'Development Status :: 5 - Production/Stable',\n        'Environment :: Console',\n        'Intended Audience :: Developers',\n        'License :: OSI Approved :: Apache Software License',\n        'Operating System :: OS Independent',\n        'Programming Language :: Python :: 3.7',\n        'Programming Language :: Python :: 3.8',\n        'Programming Language :: Python :: 3.9',\n        'Programming Language :: Python :: 3.10',\n        'Topic :: Database :: Front-Ends',\n    ],\n    cmdclass={'develop': SetupDevelop},\n)\n"
    },
    {
      "path": "piskvorky_sqlitedict/benchmarks/test_insert.py",
      "content": "import tempfile\n\nfrom sqlitedict import SqliteDict\n\n\ndef insert():\n    with tempfile.NamedTemporaryFile() as tmp:\n        for j in range(100):\n            with SqliteDict(tmp.name) as d:\n                d[\"tmp\"] = j\n                d.commit()\n\n\ndef test(benchmark):\n    benchmark(insert)\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/autocommit.py",
      "content": "import sqlitedict\n\nd = sqlitedict.SqliteDict('tests/db/autocommit.sqlite', autocommit=True)\n\nfor i in range(1000):\n    d[i] = i\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_onimport.py",
      "content": "\"\"\"Test cases for on-import logic.\"\"\"\nimport unittest\nimport sys\n\n\nclass SqliteDict_cPickleImportTest(unittest.TestCase):\n    \"\"\"Verify fallback to 'pickle' module when 'cPickle' is not found.\"\"\"\n    def setUp(self):\n        self.orig_meta_path = sys.meta_path\n        self.orig_sqlitedict = sys.modules.pop('sqlitedict', None)\n\n        class FauxMissingImport(object):\n            def __init__(self, *args):\n                self.module_names = args\n\n            def find_module(self, fullname, path=None):\n                if fullname in self.module_names:\n                    return self\n                return None\n\n            def load_module(self, name):\n                raise ImportError(\"No module named %s (FauxMissingImport)\" % (name,))\n\n        # ensure cPickle/pickle is not cached\n        sys.modules.pop('cPickle', None)\n        sys.modules.pop('pickle', None)\n\n        # add our custom importer\n        sys.meta_path.insert(0, FauxMissingImport('cPickle'))\n\n    def tearDown(self):\n        sys.meta_path = self.orig_meta_path\n        if self.orig_sqlitedict:\n            sys.modules['sqlitedict'] = self.orig_sqlitedict\n\n    def test_cpickle_fallback_to_pickle(self):\n        # exercise,\n        sqlitedict = __import__(\"sqlitedict\")\n        # verify,\n        self.assertIn('pickle', sys.modules.keys())\n        self.assertIs(sqlitedict.dumps, sys.modules['pickle'].dumps)\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_temp_db.py",
      "content": "#!/usr/bin/env python\n# -*- coding: utf-8 -*-\n#\n# This code is distributed under the terms and conditions\n# from the Apache License, Version 2.0\nimport unittest\nimport sqlitedict\n\nfrom sys import version_info\nmajor_version = version_info[0]\n\n\nclass TempSqliteDictTest(unittest.TestCase):\n\n    def setUp(self):\n        self.d = sqlitedict.SqliteDict()\n\n    def tearDown(self):\n        self.d.close()\n\n    def test_create_sqlitedict(self):\n        ''' test_create_sqlitedict\n        '''\n        self.assertIsInstance(self.d, sqlitedict.SqliteDict)\n        self.assertEqual(dict(self.d), {})\n        self.assertEqual(list(self.d), [])\n        self.assertEqual(len(self.d), 0)\n\n    def test_assign_values(self):\n        ''' test_assign_values\n        '''\n        self.d['abc'] = 'edf'\n        self.assertEqual(self.d['abc'], 'edf')\n        self.assertEqual(len(self.d), 1)\n\n    def test_clear_data(self):\n        ''' test_clear_data\n        '''\n        self.d.update(a=1, b=2, c=3)\n        self.assertEqual(len(self.d), 3)\n        self.d.clear()\n        self.assertEqual(len(self.d), 0)\n\n    def test_manage_one_record(self):\n        ''' test_manage_one_record\n        '''\n        self.d['abc'] = 'rsvp' * 100\n        self.assertEqual(self.d['abc'], 'rsvp' * 100)\n        self.d['abc'] = 100\n        self.assertEqual(self.d['abc'], 100)\n        self.assertEqual(len(self.d), 1)\n        del self.d['abc']\n        self.assertEqual(len(self.d), 0)\n        self.assertTrue(not self.d)\n\n    def test_manage_few_records(self):\n        ''' test_manage_few_records\n        '''\n        self.d['abc'] = 'lmno'\n        self.d['xyz'] = 'pdq'\n        self.assertEqual(len(self.d), 2)\n        if major_version == 2:\n            self.assertEqual(list(self.d.iteritems()), [('abc', 'lmno'), ('xyz', 'pdq')])\n        self.assertEqual(list(self.d.items()), [('abc', 'lmno'), ('xyz', 'pdq')])\n        self.assertEqual(list(self.d.values()), ['lmno', 'pdq'])\n        self.assertEqual(list(self.d.keys()), ['abc', 'xyz'])\n        self.assertEqual(list(self.d), ['abc', 'xyz'])\n\n    def test_update_records(self):\n        ''' test_update_records\n        '''\n        self.d.update([('v', 'w')], p='x', q='y', r='z')\n        self.assertEqual(len(self.d), 4)\n        # As far as I know dicts does not need to return\n        # the elements in a specified order (sort() is required )\n        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n\n    def test_handling_errors(self):\n        ''' test_handling_errors\n        '''\n        def get_value(d, k):\n            return d[k]\n\n        def remove_nonexists(d, k):\n            del d[k]\n\n        with self.assertRaises(KeyError):\n            remove_nonexists(self.d, 'abc')\n        with self.assertRaises(KeyError):\n            get_value(self.d, 'abc')\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_autocommit.py",
      "content": "import os\nimport sys\n\nimport sqlitedict\n\n\ndef test():\n    \"Verify autocommit just before program exits.\"\n    assert os.system('env PYTHONPATH=. %s tests/autocommit.py' % sys.executable) == 0\n    # The above script relies on the autocommit feature working correctly.\n    # Now, let's check if it actually worked.\n    d = sqlitedict.SqliteDict('tests/db/autocommit.sqlite')\n    for i in range(1000):\n        assert d[i] == i, \"actual: %s expected: %s\" % (d[i], i)\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_core.py",
      "content": "# std imports\nimport json\nimport unittest\nimport tempfile\nimport os\nfrom unittest.mock import patch\n\n# local\nimport sqlitedict\nfrom sqlitedict import SqliteDict\nfrom test_temp_db import TempSqliteDictTest\nfrom accessories import norm_file\n\n\nclass SqliteMiscTest(unittest.TestCase):\n\n    def test_with_statement(self):\n        \"\"\"Verify using sqlitedict as a contextmanager . \"\"\"\n        with SqliteDict() as d:\n            self.assertTrue(isinstance(d, SqliteDict))\n            self.assertEqual(dict(d), {})\n            self.assertEqual(list(d), [])\n            self.assertEqual(len(d), 0)\n\n    def test_reopen_conn(self):\n        \"\"\"Verify using a contextmanager that a connection can be reopened.\"\"\"\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        db = SqliteDict(filename=fname)\n        with db:\n            db['key'] = 'value'\n            db.commit()\n        with db:\n            db['key'] = 'value'\n            db.commit()\n\n    def test_as_str(self):\n        \"\"\"Verify SqliteDict.__str__().\"\"\"\n        # given,\n        db = SqliteDict()\n        # exercise\n        db.__str__()\n        # test when db closed\n        db.close()\n        db.__str__()\n\n    def test_as_repr(self):\n        \"\"\"Verify SqliteDict.__repr__().\"\"\"\n        # given,\n        db = SqliteDict()\n        # exercise\n        db.__repr__()\n\n    def test_directory_notfound(self):\n        \"\"\"Verify RuntimeError: directory does not exist.\"\"\"\n        # given: a non-existent directory,\n        folder = tempfile.mkdtemp(prefix='sqlitedict-test')\n        os.rmdir(folder)\n        # exercise,\n        with self.assertRaises(RuntimeError):\n            SqliteDict(filename=os.path.join(folder, 'nonexistent'))\n\n    def test_commit_nonblocking(self):\n        \"\"\"Coverage for non-blocking commit.\"\"\"\n        # given,\n        with SqliteDict(autocommit=True) as d:\n            # exercise: the implicit commit is nonblocking\n            d['key'] = 'value'\n            d.commit(blocking=False)\n\n    def test_cancel_iterate(self):\n        import time\n\n        class EndlessKeysIterator:\n            def __init__(self) -> None:\n                self.value = 0\n\n            def __iter__(self):\n                return self\n\n            def __next__(self):\n                self.value += 1\n                return [self.value]\n\n        with patch('sqlitedict.sqlite3') as mock_sqlite3:\n            ki = EndlessKeysIterator()\n            cursor = mock_sqlite3.connect().cursor()\n            cursor.__iter__.return_value = ki\n\n            with SqliteDict(autocommit=True) as d:\n                for i, k in enumerate(d.keys()):\n                    assert i + 1 == k\n                    if k > 100:\n                        break\n                assert ki.value > 101\n\n                # Release GIL, let background threads run.\n                # Don't use gc.collect because this is simulate user code.\n                time.sleep(0.01)\n\n                current = ki.value\n                time.sleep(1)\n                assert current == ki.value, 'Will not read more after iterate stop'\n\n\nclass NamedSqliteDictCreateOrReuseTest(TempSqliteDictTest):\n    \"\"\"Verify default flag='c', and flag='n' of SqliteDict().\"\"\"\n\n    def test_default_reuse_existing_flag_c(self):\n        \"\"\"Re-opening of a database does not destroy it.\"\"\"\n        # given,\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        orig_db = SqliteDict(filename=fname)\n        orig_db['key'] = 'value'\n        orig_db.commit()\n        orig_db.close()\n\n        next_db = SqliteDict(filename=fname)\n        self.assertIn('key', next_db.keys())\n        self.assertEqual(next_db['key'], 'value')\n\n    def test_overwrite_using_flag_n(self):\n        \"\"\"Re-opening of a database with flag='c' destroys it all.\"\"\"\n        # given,\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        orig_db = SqliteDict(filename=fname, tablename='sometable')\n        orig_db['key'] = 'value'\n        orig_db.commit()\n        orig_db.close()\n\n        # verify,\n        next_db = SqliteDict(filename=fname, tablename='sometable', flag='n')\n        self.assertNotIn('key', next_db.keys())\n        self.assertNotIn('value', next_db.values())\n\n    def test_unrecognized_flag(self):\n\n        def build_with_bad_flag():\n            fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n            SqliteDict(filename=fname, flag='FOO')\n\n        with self.assertRaises(RuntimeError):\n            build_with_bad_flag()\n\n    def test_readonly(self):\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        orig_db = SqliteDict(filename=fname)\n        orig_db['key'] = 'value'\n        orig_db['key_two'] = 2\n        orig_db.commit()\n        orig_db.close()\n\n        readonly_db = SqliteDict(filename=fname, flag='r')\n        self.assertTrue(readonly_db['key'] == 'value')\n        self.assertTrue(readonly_db['key_two'] == 2)\n\n        def attempt_write():\n            readonly_db['key'] = ['new_value']\n\n        def attempt_update():\n            readonly_db.update(key='value2', key_two=2.1)\n\n        def attempt_delete():\n            del readonly_db['key']\n\n        def attempt_clear():\n            readonly_db.clear()\n\n        def attempt_terminate():\n            readonly_db.terminate()\n\n        attempt_funcs = [attempt_write, attempt_update, attempt_delete, attempt_clear, attempt_terminate]\n\n        for func in attempt_funcs:\n            with self.assertRaises(RuntimeError):\n                func()\n\n    def test_readonly_table(self):\n        \"\"\"\n        Read-only access on a non-existent tablename should raise RuntimeError,\n        and not create a new (empty) table.\n        \"\"\"\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        dummy_tablename = 'table404'\n        orig_db = SqliteDict(filename=fname)\n        orig_db['key'] = 'value'\n        orig_db['key_two'] = 2\n        orig_db.commit()\n        orig_db.close()\n\n        self.assertFalse(dummy_tablename in SqliteDict.get_tablenames(fname))\n\n        with self.assertRaises(RuntimeError):\n            SqliteDict(filename=fname, tablename=dummy_tablename, flag='r')\n\n        self.assertFalse(dummy_tablename in SqliteDict.get_tablenames(fname))\n\n    def test_irregular_tablenames(self):\n        \"\"\"Irregular table names need to be quoted\"\"\"\n        def __test_irregular_tablenames(tablename):\n            filename = ':memory:'\n            db = SqliteDict(filename, tablename=tablename)\n            db['key'] = 'value'\n            db.commit()\n            self.assertEqual(db['key'], 'value')\n            db.close()\n\n        __test_irregular_tablenames('9nine')\n        __test_irregular_tablenames('outer space')\n        __test_irregular_tablenames('table with a \"quoted\" name')\n        __test_irregular_tablenames(\"table with a \\\"quoted \\xe1cute\\\" name\")\n\n    def test_overwrite_using_flag_w(self):\n        \"\"\"Re-opening of a database with flag='w' destroys only the target table.\"\"\"\n        # given,\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        orig_db_1 = SqliteDict(filename=fname, tablename='one')\n        orig_db_1['key'] = 'value'\n        orig_db_1.commit()\n        orig_db_1.close()\n\n        orig_db_2 = SqliteDict(filename=fname, tablename='two')\n        orig_db_2['key'] = 'value'\n        orig_db_2.commit()\n        orig_db_2.close()\n\n        # verify, when re-opening table space 'one' with flag='2', we destroy\n        # its contents.  However, when re-opening table space 'two' with\n        # default flag='r', its contents remain.\n        next_db_1 = SqliteDict(filename=fname, tablename='one', flag='w')\n        self.assertNotIn('key', next_db_1.keys())\n\n        next_db_2 = SqliteDict(filename=fname, tablename='two')\n        self.assertIn('key', next_db_2.keys())\n\n\nclass SqliteDictTerminateTest(unittest.TestCase):\n\n    def test_terminate_instead_close(self):\n        ''' make terminate() instead of close()\n        '''\n        d = sqlitedict.open('tests/db/sqlitedict-terminate.sqlite')\n        d['abc'] = 'def'\n        d.commit()\n        self.assertEqual(d['abc'], 'def')\n        d.terminate()\n        self.assertFalse(os.path.isfile('tests/db/sqlitedict-terminate.sqlite'))\n\n\nclass SqliteDictTerminateFailTest(unittest.TestCase):\n    \"\"\"Provide Coverage for SqliteDict.terminate().\"\"\"\n\n    def setUp(self):\n        self.fname = norm_file('tests/db-permdenied/sqlitedict.sqlite')\n        self.db = SqliteDict(filename=self.fname)\n        os.chmod(self.fname, 0o000)\n        os.chmod(os.path.dirname(self.fname), 0o000)\n\n    def tearDown(self):\n        os.chmod(os.path.dirname(self.fname), 0o700)\n        os.chmod(self.fname, 0o600)\n        os.unlink(self.fname)\n        os.rmdir(os.path.dirname(self.fname))\n\n    def test_terminate_cannot_delete(self):\n        # exercise,\n        self.db.terminate()  # deletion failed, but no exception raised!\n\n        # verify,\n        os.chmod(os.path.dirname(self.fname), 0o700)\n        os.chmod(self.fname, 0o600)\n        self.assertTrue(os.path.exists(self.fname))\n\n\nclass SqliteDictJsonSerializationTest(unittest.TestCase):\n    def setUp(self):\n        self.fname = norm_file('tests/db-json/sqlitedict.sqlite')\n        self.db = SqliteDict(\n            filename=self.fname, tablename='test', encode=json.dumps, decode=json.loads\n        )\n\n    def tearDown(self):\n        self.db.close()\n        os.unlink(self.fname)\n        os.rmdir(os.path.dirname(self.fname))\n\n    def get_json(self, key):\n        return self.db.conn.select_one('SELECT value FROM test WHERE key = ?', (self.db.encode_key(key),))[0]\n\n    def test_int(self):\n        self.db['test'] = -42\n        assert self.db['test'] == -42\n        assert self.get_json('test') == '-42'\n\n    def test_str(self):\n        test_str = u'Test \\u30c6\\u30b9\\u30c8'\n        self.db['test'] = test_str\n        assert self.db['test'] == test_str\n        assert self.get_json('test') == r'\"Test \\u30c6\\u30b9\\u30c8\"'\n\n    def test_bool(self):\n        self.db['test'] = False\n        assert self.db['test'] is False\n        assert self.get_json('test') == 'false'\n\n    def test_none(self):\n        self.db['test'] = None\n        assert self.db['test'] is None\n        assert self.get_json('test') == 'null'\n\n    def test_complex_struct(self):\n        test_value = {\n            'version': 2.5,\n            'items': ['one', 'two'],\n        }\n        self.db['test'] = test_value\n        assert self.db['test'] == test_value\n        assert self.get_json('test') == json.dumps(test_value)\n\n\nclass TablenamesTest(unittest.TestCase):\n    def tearDown(self):\n        for f in ('tablenames-test-1.sqlite', 'tablenames-test-2.sqlite'):\n            path = norm_file(os.path.join('tests/db', f))\n            if os.path.isfile(path):\n                os.unlink(path)\n\n    def test_tablenames_unnamed(self):\n        fname = norm_file('tests/db/tablenames-test-1.sqlite')\n        SqliteDict(fname)\n        self.assertEqual(SqliteDict.get_tablenames(fname), ['unnamed'])\n\n    def test_tablenams_named(self):\n        fname = norm_file('tests/db/tablenames-test-2.sqlite')\n        with SqliteDict(fname, tablename='table1'):\n            self.assertEqual(SqliteDict.get_tablenames(fname), ['table1'])\n        with SqliteDict(fname, tablename='table2'):\n            self.assertEqual(SqliteDict.get_tablenames(fname), ['table1', 'table2'])\n\n        tablenames = SqliteDict.get_tablenames('tests/db/tablenames-test-2.sqlite')\n        self.assertEqual(tablenames, ['table1', 'table2'])\n\n\nclass SqliteDictKeySerializationTest(unittest.TestCase):\n    def setUp(self):\n        self.fname = norm_file('tests/db-encode-key/sqlitedict.sqlite')\n        self.db = SqliteDict(\n            filename=self.fname, tablename='test',\n            encode_key=sqlitedict.encode_key, decode_key=sqlitedict.decode_key,\n        )\n\n    def test_nonstr_keys(self):\n        self.db['test'] = -42\n        assert self.db['test'] == -42\n        self.db[(0, 1, 2)] = 17\n        assert self.db[(0, 1, 2)] == 17\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_named_db.py",
      "content": "import sqlitedict\nfrom test_temp_db import TempSqliteDictTest\nfrom accessories import norm_file\n\n\nclass InMemorySqliteDictTest(TempSqliteDictTest):\n\n    def setUp(self):\n        self.d = sqlitedict.SqliteDict(filename=':memory:', autocommit=True)\n\n    def tearDown(self):\n        self.d.terminate()\n\n\nclass NamedSqliteDictTest(TempSqliteDictTest):\n\n    def setUp(self):\n        db = norm_file('tests/db/sqlitedict-with-def.sqlite')\n        self.d = sqlitedict.SqliteDict(filename=db)\n\n\nclass CreateNewSqliteDictTest(TempSqliteDictTest):\n\n    def setUp(self):\n        db = norm_file('tests/db/sqlitedict-with-n-flag.sqlite')\n        self.d = sqlitedict.SqliteDict(filename=db, flag=\"n\")\n\n    def tearDown(self):\n        self.d.terminate()\n\n\nclass StartsWithEmptySqliteDictTest(TempSqliteDictTest):\n\n    def setUp(self):\n        db = norm_file('tests/db/sqlitedict-with-w-flag.sqlite')\n        self.d = sqlitedict.SqliteDict(filename=db, flag=\"w\")\n\n    def tearDown(self):\n        self.d.terminate()\n\n\nclass SqliteDictAutocommitTest(TempSqliteDictTest):\n\n    def setUp(self):\n        db = norm_file('tests/db/sqlitedict-autocommit.sqlite')\n        self.d = sqlitedict.SqliteDict(filename=db, autocommit=True)\n\n    def tearDown(self):\n        self.d.terminate()\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/accessories.py",
      "content": "\"\"\"Accessories for test cases.\"\"\"\nimport os\n\n\ndef norm_file(fname):\n    \"\"\"Normalize test filename, creating a directory path to it if necessary\"\"\"\n    fname = os.path.abspath(fname)\n    dirname = os.path.dirname(fname)\n    if not os.path.exists(dirname):\n        os.makedirs(dirname)\n    return fname\n"
    },
    {
      "path": "piskvorky_sqlitedict/release/summarize_pr.py",
      "content": "#!/usr/bin/env python\nimport json\nimport sys\nimport urllib.request\n\n\ndef copy_to_clipboard(text):\n    try:\n        import pyperclip\n    except ImportError:\n        print('pyperclip <https://pypi.org/project/pyperclip/> is missing.', file=sys.stderr)\n        print('copy-paste the following text manually:', file=sys.stderr)\n        print('  ' + text, file=sys.stderr)\n    else:\n        pyperclip.copy(text)\n\n\nfor prid in sys.argv[1:]:\n    url = \"https://api.github.com/repos/RaRe-Technologies/sqlitedict/pulls/%s\" % prid\n    with urllib.request.urlopen(url) as fin:\n        prinfo = json.load(fin)\n\n    prinfo['user_login'] = prinfo['user']['login']\n    prinfo['user_html_url'] = prinfo['user']['html_url']\n    text = '- %(title)s (PR [#%(number)s](%(html_url)s), [@%(user_login)s](%(user_html_url)s))' % prinfo\n    print(text)\n"
    }
  ],
  "OriginCode": [
    {
      "path": "piskvorky_sqlitedict/sqlitedict.py",
      "content": "#!/usr/bin/env python\n# -*- coding: utf-8 -*-\n#\n# This code is distributed under the terms and conditions\n# from the Apache License, Version 2.0\n#\n# http://opensource.org/licenses/apache2.0.php\n#\n# This code was inspired by:\n#  * http://code.activestate.com/recipes/576638-draft-for-an-sqlite3-based-dbm/\n#  * http://code.activestate.com/recipes/526618/\n\n\"\"\"\nA lightweight wrapper around Python's sqlite3 database, with a dict-like interface\nand multi-thread access support::\n\n>>> mydict = SqliteDict('some.db', autocommit=True) # the mapping will be persisted to file `some.db`\n>>> mydict['some_key'] = any_picklable_object\n>>> print mydict['some_key']\n>>> print len(mydict) # etc... all dict functions work\n\nPickle is used internally to serialize the values. Keys are strings.\n\nIf you don't use autocommit (default is no autocommit for performance), then\ndon't forget to call `mydict.commit()` when done with a transaction.\n\n\"\"\"\n\nimport sqlite3\nimport os\nimport sys\nimport tempfile\nimport threading\nimport logging\nimport traceback\nfrom base64 import b64decode, b64encode\nimport weakref\n\n__version__ = '2.1.0'\n\n\ndef reraise(tp, value, tb=None):\n    if value is None:\n        value = tp()\n    if value.__traceback__ is not tb:\n        raise value.with_traceback(tb)\n    raise value\n\n\ntry:\n    from cPickle import dumps, loads, HIGHEST_PROTOCOL as PICKLE_PROTOCOL\nexcept ImportError:\n    from pickle import dumps, loads, HIGHEST_PROTOCOL as PICKLE_PROTOCOL\n\n# some Python 3 vs 2 imports\ntry:\n    from collections import UserDict as DictClass\nexcept ImportError:\n    from UserDict import DictMixin as DictClass\n\ntry:\n    from queue import Queue\nexcept ImportError:\n    from Queue import Queue\n\n\nlogger = logging.getLogger(__name__)\n\n#\n# There's a thread that holds the actual SQL connection (SqliteMultithread).\n# We communicate with this thread via queues (request and responses).\n# The requests can either be SQL commands or one of the \"special\" commands\n# below:\n#\n# _REQUEST_CLOSE: request that the SQL connection be closed\n# _REQUEST_COMMIT: request that any changes be committed to the DB\n#\n# Responses are either SQL records (e.g. results of a SELECT) or the magic\n# _RESPONSE_NO_MORE command, which indicates nothing else will ever be written\n# to the response queue.\n#\n_REQUEST_CLOSE = '--close--'\n_REQUEST_COMMIT = '--commit--'\n_RESPONSE_NO_MORE = '--no more--'\n\n#\n# We work with weak references for better memory efficiency.\n# Dereferencing, checking the referent queue still exists, and putting to it\n# is boring and repetitive, so we have a _put function to handle it for us.\n#\n_PUT_OK, _PUT_REFERENT_DESTROYED, _PUT_NOOP = 0, 1, 2\n\n\ndef _put(queue_reference, item):\n    if queue_reference is not None:\n        queue = queue_reference()\n        if queue is None:\n            #\n            # We got a reference to a queue, but that queue no longer exists\n            #\n            retval = _PUT_REFERENT_DESTROYED\n        else:\n            queue.put(item)\n            retval = _PUT_OK\n\n        del queue\n        return retval\n\n    #\n    # We didn't get a reference to a queue, so do nothing (no-op).\n    #\n    return _PUT_NOOP\n\n\ndef open(*args, **kwargs):\n    \"\"\"See documentation of the SqliteDict class.\"\"\"\n    return SqliteDict(*args, **kwargs)\n\n\ndef encode(obj):\n    \"\"\"Serialize an object using pickle to a binary format accepted by SQLite.\"\"\"\n    return sqlite3.Binary(dumps(obj, protocol=PICKLE_PROTOCOL))\n\n\ndef decode(obj):\n    \"\"\"Deserialize objects retrieved from SQLite.\"\"\"\n    return loads(bytes(obj))\n\n\ndef encode_key(key):\n    \"\"\"Serialize a key using pickle + base64 encoding to text accepted by SQLite.\"\"\"\n    return b64encode(dumps(key, protocol=PICKLE_PROTOCOL)).decode(\"ascii\")\n\n\ndef decode_key(key):\n    \"\"\"Deserialize a key retrieved from SQLite.\"\"\"\n    return loads(b64decode(key.encode(\"ascii\")))\n\n\ndef identity(obj):\n    \"\"\"Identity f(x) = x function for encoding/decoding.\"\"\"\n    return obj\n\n\nclass SqliteDict(DictClass):\n    VALID_FLAGS = ['c', 'r', 'w', 'n']\n\n    def __init__(self, filename=None, tablename='unnamed', flag='c',\n                 autocommit=False, journal_mode=\"DELETE\", encode=encode,\n                 decode=decode, encode_key=identity, decode_key=identity,\n                 timeout=5, outer_stack=True):\n        \"\"\"\n        Initialize a thread-safe sqlite-backed dictionary. The dictionary will\n        be a table `tablename` in database file `filename`. A single file (=database)\n        may contain multiple tables.\n\n        If no `filename` is given, a random file in temp will be used (and deleted\n        from temp once the dict is closed/deleted).\n\n        If you enable `autocommit`, changes will be committed after each operation\n        (more inefficient but safer). Otherwise, changes are committed on `self.commit()`,\n        `self.clear()` and `self.close()`.\n\n        Set `journal_mode` to 'OFF' if you're experiencing sqlite I/O problems\n        or if you need performance and don't care about crash-consistency.\n\n        Set `outer_stack` to False to disable the output of the outer exception\n        to the error logs.  This may improve the efficiency of sqlitedict\n        operation at the expense of a detailed exception trace.\n\n        The `flag` parameter. Exactly one of:\n          'c': default mode, open for read/write, creating the db/table if necessary.\n          'w': open for r/w, but drop `tablename` contents first (start with empty table)\n          'r': open as read-only\n          'n': create a new database (erasing any existing tables, not just `tablename`!).\n\n        The `encode` and `decode` parameters are used to customize how the values\n        are serialized and deserialized.\n        The `encode` parameter must be a function that takes a single Python\n        object and returns a serialized representation.\n        The `decode` function must be a function that takes the serialized\n        representation produced by `encode` and returns a deserialized Python\n        object.\n        The default is to use pickle.\n\n        The `timeout` defines the maximum time (in seconds) to wait for initial Thread startup.\n\n        \"\"\"\n        self.in_temp = filename is None\n        if self.in_temp:\n            fd, filename = tempfile.mkstemp(prefix='sqldict')\n            os.close(fd)\n\n        if flag not in SqliteDict.VALID_FLAGS:\n            raise RuntimeError(\"Unrecognized flag: %s\" % flag)\n        self.flag = flag\n\n        if flag == 'n':\n            if os.path.exists(filename):\n                os.remove(filename)\n\n        dirname = os.path.dirname(filename)\n        if dirname:\n            if not os.path.exists(dirname):\n                raise RuntimeError('Error! The directory does not exist, %s' % dirname)\n\n        self.filename = filename\n\n        # Use standard SQL escaping of double quote characters in identifiers, by doubling them.\n        # See https://github.com/RaRe-Technologies/sqlitedict/pull/113\n        self.tablename = tablename.replace('\"', '\"\"')\n\n        self.autocommit = autocommit\n        self.journal_mode = journal_mode\n        self.encode = encode\n        self.decode = decode\n        self.encode_key = encode_key\n        self.decode_key = decode_key\n        self._outer_stack = outer_stack\n\n        logger.debug(\"opening Sqlite table %r in %r\" % (tablename, filename))\n        self.conn = self._new_conn()\n        if self.flag == 'r':\n            if self.tablename not in SqliteDict.get_tablenames(self.filename):\n                msg = 'Refusing to create a new table \"%s\" in read-only DB mode' % tablename\n                raise RuntimeError(msg)\n        else:\n            MAKE_TABLE = 'CREATE TABLE IF NOT EXISTS \"%s\" (key TEXT PRIMARY KEY, value BLOB)' % self.tablename\n            self.conn.execute(MAKE_TABLE)\n            self.conn.commit()\n        if flag == 'w':\n            self.clear()\n\n    def _new_conn(self):\n        return SqliteMultithread(\n            self.filename,\n            autocommit=self.autocommit,\n            journal_mode=self.journal_mode,\n            outer_stack=self._outer_stack,\n        )\n\n    def __enter__(self):\n        if not hasattr(self, 'conn') or self.conn is None:\n            self.conn = self._new_conn()\n        return self\n\n    def __exit__(self, *exc_info):\n        self.close()\n\n    def __str__(self):\n        return \"SqliteDict(%s)\" % (self.filename)\n\n    def __repr__(self):\n        return str(self)  # no need of something complex\n\n    def __len__(self):\n        # `select count (*)` is super slow in sqlite (does a linear scan!!)\n        # As a result, len() is very slow too once the table size grows beyond trivial.\n        # We could keep the total count of rows ourselves, by means of triggers,\n        # but that seems too complicated and would slow down normal operation\n        # (insert/delete etc).\n        GET_LEN = 'SELECT COUNT(*) FROM \"%s\"' % self.tablename\n        rows = self.conn.select_one(GET_LEN)[0]\n        return rows if rows is not None else 0\n\n    def __bool__(self):\n        # No elements is False, otherwise True\n        GET_MAX = 'SELECT MAX(ROWID) FROM \"%s\"' % self.tablename\n        m = self.conn.select_one(GET_MAX)[0]\n        # Explicit better than implicit and bla bla\n        return True if m is not None else False\n\n    def iterkeys(self):\n        GET_KEYS = 'SELECT key FROM \"%s\" ORDER BY rowid' % self.tablename\n        for key in self.conn.select(GET_KEYS):\n            yield self.decode_key(key[0])\n\n    def itervalues(self):\n        GET_VALUES = 'SELECT value FROM \"%s\" ORDER BY rowid' % self.tablename\n        for value in self.conn.select(GET_VALUES):\n            yield self.decode(value[0])\n\n    def iteritems(self):\n        GET_ITEMS = 'SELECT key, value FROM \"%s\" ORDER BY rowid' % self.tablename\n        for key, value in self.conn.select(GET_ITEMS):\n            yield self.decode_key(key), self.decode(value)\n\n    def keys(self):\n        return self.iterkeys()\n\n    def values(self):\n        return self.itervalues()\n\n    def items(self):\n        return self.iteritems()\n\n    def __contains__(self, key):\n        HAS_ITEM = 'SELECT 1 FROM \"%s\" WHERE key = ?' % self.tablename\n        return self.conn.select_one(HAS_ITEM, (self.encode_key(key),)) is not None\n\n    def __getitem__(self, key):\n        GET_ITEM = 'SELECT value FROM \"%s\" WHERE key = ?' % self.tablename\n        item = self.conn.select_one(GET_ITEM, (self.encode_key(key),))\n        if item is None:\n            raise KeyError(key)\n        return self.decode(item[0])\n\n    def __setitem__(self, key, value):\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to write to read-only SqliteDict')\n\n        ADD_ITEM = 'REPLACE INTO \"%s\" (key, value) VALUES (?,?)' % self.tablename\n        self.conn.execute(ADD_ITEM, (self.encode_key(key), self.encode(value)))\n        if self.autocommit:\n            self.commit()\n\n    def __delitem__(self, key):\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to delete from read-only SqliteDict')\n\n        if key not in self:\n            raise KeyError(key)\n        DEL_ITEM = 'DELETE FROM \"%s\" WHERE key = ?' % self.tablename\n        self.conn.execute(DEL_ITEM, (self.encode_key(key),))\n        if self.autocommit:\n            self.commit()\n\n    def update(self, items=(), **kwds):\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to update read-only SqliteDict')\n\n        try:\n            items = items.items()\n        except AttributeError:\n            pass\n        items = [(self.encode_key(k), self.encode(v)) for k, v in items]\n\n        UPDATE_ITEMS = 'REPLACE INTO \"%s\" (key, value) VALUES (?, ?)' % self.tablename\n        self.conn.executemany(UPDATE_ITEMS, items)\n        if kwds:\n            self.update(kwds)\n        if self.autocommit:\n            self.commit()\n\n    def __iter__(self):\n        return self.iterkeys()\n\n    def clear(self):\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to clear read-only SqliteDict')\n\n        # avoid VACUUM, as it gives \"OperationalError: database schema has changed\"\n        CLEAR_ALL = 'DELETE FROM \"%s\";' % self.tablename\n        self.conn.commit()\n        self.conn.execute(CLEAR_ALL)\n        self.conn.commit()\n\n    @staticmethod\n    def get_tablenames(filename):\n        \"\"\"get the names of the tables in an sqlite db as a list\"\"\"\n        if not os.path.isfile(filename):\n            raise IOError('file %s does not exist' % (filename))\n        GET_TABLENAMES = 'SELECT name FROM sqlite_master WHERE type=\"table\"'\n        with sqlite3.connect(filename) as conn:\n            cursor = conn.execute(GET_TABLENAMES)\n            res = cursor.fetchall()\n\n        return [name[0] for name in res]\n\n    def commit(self, blocking=True):\n        \"\"\"\n        Persist all data to disk.\n\n        When `blocking` is False, the commit command is queued, but the data is\n        not guaranteed persisted (default implication when autocommit=True).\n        \"\"\"\n        if self.conn is not None:\n            self.conn.commit(blocking)\n    sync = commit\n\n    def close(self, do_log=True, force=False):\n        if do_log:\n            logger.debug(\"closing %s\" % self)\n        if hasattr(self, 'conn') and self.conn is not None:\n            if self.conn.autocommit and not force:\n                # typically calls to commit are non-blocking when autocommit is\n                # used.  However, we need to block on close() to ensure any\n                # awaiting exceptions are handled and that all data is\n                # persisted to disk before returning.\n                self.conn.commit(blocking=True)\n            self.conn.close(force=force)\n            self.conn = None\n        if self.in_temp:\n            try:\n                os.remove(self.filename)\n            except Exception:\n                pass\n\n    def terminate(self):\n        \"\"\"Delete the underlying database file. Use with care.\"\"\"\n        if self.flag == 'r':\n            raise RuntimeError('Refusing to terminate read-only SqliteDict')\n\n        self.close()\n\n        if self.filename == ':memory:':\n            return\n\n        logger.info(\"deleting %s\" % self.filename)\n        try:\n            if os.path.isfile(self.filename):\n                os.remove(self.filename)\n        except (OSError, IOError):\n            logger.exception(\"failed to delete %s\" % (self.filename))\n\n    def __del__(self):\n        # like close(), but assume globals are gone by now (do not log!)\n        try:\n            self.close(do_log=False, force=True)\n        except Exception:\n            # prevent error log flood in case of multiple SqliteDicts\n            # closed after connection lost (exceptions are always ignored\n            # in __del__ method.\n            pass\n\n\nclass SqliteMultithread(threading.Thread):\n    \"\"\"\n    Wrap sqlite connection in a way that allows concurrent requests from multiple threads.\n\n    This is done by internally queueing the requests and processing them sequentially\n    in a separate thread (in the same order they arrived).\n\n    \"\"\"\n    def __init__(self, filename, autocommit, journal_mode, outer_stack=True):\n        super(SqliteMultithread, self).__init__()\n        self.filename = filename\n        self.autocommit = autocommit\n        self.journal_mode = journal_mode\n        # use request queue of unlimited size\n        self.reqs = Queue()\n        self.daemon = True\n        self._outer_stack = outer_stack\n        self.log = logging.getLogger('sqlitedict.SqliteMultithread')\n\n        #\n        # Parts of this object's state get accessed from different threads, so\n        # we use synchronization to avoid race conditions.  For example,\n        # .exception gets set inside the new daemon thread that we spawned, but\n        # gets read from the main thread.  This is particularly important\n        # during initialization: the Thread needs some time to actually start\n        # working, and until this happens, any calls to e.g.\n        # check_raise_error() will prematurely return None, meaning all is\n        # well.  If the that connection happens to fail, we'll never know about\n        # it, and instead wait for a result that never arrives (effectively,\n        # deadlocking).  Locking solves this problem by eliminating the race\n        # condition.\n        #\n        self._lock = threading.Lock()\n        self._lock.acquire()\n        self.exception = None\n\n        self.start()\n\n    def _connect(self):\n        \"\"\"Connect to the underlying database.\n\n        Raises an exception on failure.  Returns the connection and cursor on success.\n        \"\"\"\n        try:\n            if self.autocommit:\n                conn = sqlite3.connect(self.filename, isolation_level=None, check_same_thread=False)\n            else:\n                conn = sqlite3.connect(self.filename, check_same_thread=False)\n        except Exception:\n            self.log.exception(\"Failed to initialize connection for filename: %s\" % self.filename)\n            self.exception = sys.exc_info()\n            raise\n\n        try:\n            conn.execute('PRAGMA journal_mode = %s' % self.journal_mode)\n            conn.text_factory = str\n            cursor = conn.cursor()\n            conn.commit()\n            cursor.execute('PRAGMA synchronous=OFF')\n        except Exception:\n            self.log.exception(\"Failed to execute PRAGMA statements.\")\n            self.exception = sys.exc_info()\n            raise\n\n        return conn, cursor\n\n    def run(self):\n        #\n        # Nb. this is what actually runs inside the new daemon thread.\n        # self._lock is locked at this stage - see the initializer function.\n        #\n        try:\n            conn, cursor = self._connect()\n        finally:\n            self._lock.release()\n\n        res_ref = None\n        while True:\n            #\n            # req: an SQL command or one of the --magic-- commands we use internally\n            # arg: arguments for the command\n            # res_ref: a weak reference to the queue into which responses must be placed\n            # outer_stack: the outer stack, for producing more informative traces in case of error\n            #\n            req, arg, res_ref, outer_stack = self.reqs.get()\n\n            if req == _REQUEST_CLOSE:\n                assert res_ref, ('--close-- without return queue', res_ref)\n                break\n            elif req == _REQUEST_COMMIT:\n                conn.commit()\n                _put(res_ref, _RESPONSE_NO_MORE)\n            else:\n                try:\n                    cursor.execute(req, arg)\n                except Exception:\n                    with self._lock:\n                        self.exception = (e_type, e_value, e_tb) = sys.exc_info()\n\n                    inner_stack = traceback.extract_stack()\n\n                    # An exception occurred in our thread, but we may not\n                    # immediately able to throw it in our calling thread, if it has\n                    # no return `res` queue: log as level ERROR both the inner and\n                    # outer exception immediately.\n                    #\n                    # Any iteration of res.get() or any next call will detect the\n                    # inner exception and re-raise it in the calling Thread; though\n                    # it may be confusing to see an exception for an unrelated\n                    # statement, an ERROR log statement from the 'sqlitedict.*'\n                    # namespace contains the original outer stack location.\n                    self.log.error('Inner exception:')\n                    for item in traceback.format_list(inner_stack):\n                        self.log.error(item)\n                    self.log.error('')  # deliniate traceback & exception w/blank line\n                    for item in traceback.format_exception_only(e_type, e_value):\n                        self.log.error(item)\n\n                    self.log.error('')  # exception & outer stack w/blank line\n\n                    if self._outer_stack:\n                        self.log.error('Outer stack:')\n                        for item in traceback.format_list(outer_stack):\n                            self.log.error(item)\n                        self.log.error('Exception will be re-raised at next call.')\n                    else:\n                        self.log.error(\n                            'Unable to show the outer stack. Pass '\n                            'outer_stack=True when initializing the '\n                            'SqliteDict instance to show the outer stack.'\n                        )\n\n                if res_ref:\n                    for rec in cursor:\n                        if _put(res_ref, rec) == _PUT_REFERENT_DESTROYED:\n                            #\n                            # The queue we are sending responses to got garbage\n                            # collected.  Nobody is listening anymore, so we\n                            # stop sending responses.\n                            #\n                            break\n\n                    _put(res_ref, _RESPONSE_NO_MORE)\n\n                if self.autocommit:\n                    conn.commit()\n\n        self.log.debug('received: %s, send: --no more--', req)\n        conn.close()\n\n        _put(res_ref, _RESPONSE_NO_MORE)\n\n    def check_raise_error(self):\n        \"\"\"\n        Check for and raise exception for any previous sqlite query.\n\n        For the `execute*` family of method calls, such calls are non-blocking and any\n        exception raised in the thread cannot be handled by the calling Thread (usually\n        MainThread).  This method is called on `close`, and prior to any subsequent\n        calls to the `execute*` methods to check for and raise an exception in a\n        previous call to the MainThread.\n        \"\"\"\n        with self._lock:\n            if self.exception:\n                e_type, e_value, e_tb = self.exception\n\n                # clear self.exception, if the caller decides to handle such\n                # exception, we should not repeatedly re-raise it.\n                self.exception = None\n\n                self.log.error('An exception occurred from a previous statement, view '\n                               'the logging namespace \"sqlitedict\" for outer stack.')\n\n                # The third argument to raise is the traceback object, and it is\n                # substituted instead of the current location as the place where\n                # the exception occurred, this is so that when using debuggers such\n                # as `pdb', or simply evaluating the naturally raised traceback, we\n                # retain the original (inner) location of where the exception\n                # occurred.\n                reraise(e_type, e_value, e_tb)\n\n    def execute(self, req, arg=None, res=None):\n        \"\"\"\n        `execute` calls are non-blocking: just queue up the request and return immediately.\n\n        :param req: The request (an SQL command)\n        :param arg: Arguments to the SQL command\n        :param res: A queue in which to place responses as they become available\n        \"\"\"\n        self.check_raise_error()\n        stack = None\n\n        if self._outer_stack:\n            # NOTE: This might be a lot of information to pump into an input\n            # queue, affecting performance.  I've also seen earlier versions of\n            # jython take a severe performance impact for throwing exceptions\n            # so often.\n            stack = traceback.extract_stack()[:-1]\n\n        #\n        # We pass a weak reference to the response queue instead of a regular\n        # reference, because we want the queues to be garbage-collected\n        # more aggressively.\n        #\n        res_ref = None\n        if res:\n            res_ref = weakref.ref(res)\n\n        self.reqs.put((req, arg or tuple(), res_ref, stack))\n\n    def executemany(self, req, items):\n        for item in items:\n            self.execute(req, item)\n        self.check_raise_error()\n\n    def select(self, req, arg=None):\n        \"\"\"\n        Unlike sqlite's native select, this select doesn't handle iteration efficiently.\n\n        The result of `select` starts filling up with values as soon as the\n        request is dequeued, and although you can iterate over the result normally\n        (`for res in self.select(): ...`), the entire result will be in memory.\n        \"\"\"\n        res = Queue()  # results of the select will appear as items in this queue\n        self.execute(req, arg, res)\n        while True:\n            rec = res.get()\n            self.check_raise_error()\n            if rec == _RESPONSE_NO_MORE:\n                break\n            yield rec\n\n    def select_one(self, req, arg=None):\n        \"\"\"Return only the first row of the SELECT, or None if there are no matching rows.\"\"\"\n        try:\n            return next(iter(self.select(req, arg)))\n        except StopIteration:\n            return None\n\n    def commit(self, blocking=True):\n        if blocking:\n            # by default, we await completion of commit() unless\n            # blocking=False.  This ensures any available exceptions for any\n            # previous statement are thrown before returning, and that the\n            # data has actually persisted to disk!\n            self.select_one(_REQUEST_COMMIT)\n        else:\n            # otherwise, we fire and forget as usual.\n            self.execute(_REQUEST_COMMIT)\n\n    def close(self, force=False):\n        if force:\n            # If a SqliteDict is being killed or garbage-collected, then select_one()\n            # could hang forever because run() might already have exited and therefore\n            # can't process the request. Instead, push the close command to the requests\n            # queue directly. If run() is still alive, it will exit gracefully. If not,\n            # then there's nothing we can do anyway.\n            self.reqs.put((_REQUEST_CLOSE, None, weakref.ref(Queue()), None))\n        else:\n            # we abuse 'select' to \"iter\" over a \"--close--\" statement so that we\n            # can confirm the completion of close before joining the thread and\n            # returning (by semaphore '--no more--'\n            self.select_one(_REQUEST_CLOSE)\n            self.join()\n\n\n#\n# This is here for .github/workflows/release.yml\n#\nif __name__ == '__main__':\n    print(__version__)\n"
    },
    {
      "path": "piskvorky_sqlitedict/setup.py",
      "content": "#!/usr/bin/env python\n# -*- coding: utf-8 -*-\n#\n# This code is distributed under the terms and conditions\n# from the Apache License, Version 2.0\n#\n# http://opensource.org/licenses/apache2.0.php\n\n\"\"\"\nRun with:\n\npython ./setup.py install\n\"\"\"\n\nimport os\nimport io\nimport subprocess\n\nimport setuptools.command.develop\nfrom setuptools import setup\n\n\ndef read(fname):\n    path = os.path.join(os.path.dirname(__file__), fname)\n    return io.open(path, encoding='utf8').read()\n\n\nclass SetupDevelop(setuptools.command.develop.develop):\n    \"\"\"Docstring is overwritten.\"\"\"\n\n    def run(self):\n        \"\"\"\n        Prepare environment for development.\n\n        - Ensures 'nose' and 'coverage.py' are installed for testing.\n        - Call super()'s run method.\n        \"\"\"\n        subprocess.check_call(('pip', 'install', 'nose', 'coverage'))\n\n        # Call super() (except develop is an old-style class, so we must call\n        # directly). The effect is that the development egg-link is installed.\n        setuptools.command.develop.develop.run(self)\n\n\nSetupDevelop.__doc__ = setuptools.command.develop.develop.__doc__\n\n\nsetup(\n    name='sqlitedict',\n    version='2.1.0',\n    description='Persistent dict in Python, backed up by sqlite3 and pickle, multithread-safe.',\n    long_description=read('README.rst'),\n\n    py_modules=['sqlitedict'],\n\n    # there is a bug in python2.5, preventing distutils from using any non-ascii characters :(\n    # http://bugs.python.org/issue2562\n    author='Radim Rehurek, Victor R. Escobar, Andrey Usov, Prasanna Swaminathan, Jeff Quast',\n    author_email=\"me@radimrehurek.com\",\n    maintainer='Radim Rehurek',\n    maintainer_email='me@radimrehurek.com',\n\n    url='https://github.com/piskvorky/sqlitedict',\n    download_url='http://pypi.python.org/pypi/sqlitedict',\n\n    keywords='sqlite, persistent dict, multithreaded',\n\n    license='Apache 2.0',\n    platforms='any',\n\n    classifiers=[  # from http://pypi.python.org/pypi?%3Aaction=list_classifiers\n        'Development Status :: 5 - Production/Stable',\n        'Environment :: Console',\n        'Intended Audience :: Developers',\n        'License :: OSI Approved :: Apache Software License',\n        'Operating System :: OS Independent',\n        'Programming Language :: Python :: 3.7',\n        'Programming Language :: Python :: 3.8',\n        'Programming Language :: Python :: 3.9',\n        'Programming Language :: Python :: 3.10',\n        'Topic :: Database :: Front-Ends',\n    ],\n    cmdclass={'develop': SetupDevelop},\n)\n"
    },
    {
      "path": "piskvorky_sqlitedict/benchmarks/test_insert.py",
      "content": "import tempfile\n\nfrom sqlitedict import SqliteDict\n\n\ndef insert():\n    with tempfile.NamedTemporaryFile() as tmp:\n        for j in range(100):\n            with SqliteDict(tmp.name) as d:\n                d[\"tmp\"] = j\n                d.commit()\n\n\ndef test(benchmark):\n    benchmark(insert)\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/autocommit.py",
      "content": "import sqlitedict\n\nd = sqlitedict.SqliteDict('tests/db/autocommit.sqlite', autocommit=True)\n\nfor i in range(1000):\n    d[i] = i\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_onimport.py",
      "content": "\"\"\"Test cases for on-import logic.\"\"\"\nimport unittest\nimport sys\n\n\nclass SqliteDict_cPickleImportTest(unittest.TestCase):\n    \"\"\"Verify fallback to 'pickle' module when 'cPickle' is not found.\"\"\"\n    def setUp(self):\n        self.orig_meta_path = sys.meta_path\n        self.orig_sqlitedict = sys.modules.pop('sqlitedict', None)\n\n        class FauxMissingImport(object):\n            def __init__(self, *args):\n                self.module_names = args\n\n            def find_module(self, fullname, path=None):\n                if fullname in self.module_names:\n                    return self\n                return None\n\n            def load_module(self, name):\n                raise ImportError(\"No module named %s (FauxMissingImport)\" % (name,))\n\n        # ensure cPickle/pickle is not cached\n        sys.modules.pop('cPickle', None)\n        sys.modules.pop('pickle', None)\n\n        # add our custom importer\n        sys.meta_path.insert(0, FauxMissingImport('cPickle'))\n\n    def tearDown(self):\n        sys.meta_path = self.orig_meta_path\n        if self.orig_sqlitedict:\n            sys.modules['sqlitedict'] = self.orig_sqlitedict\n\n    def test_cpickle_fallback_to_pickle(self):\n        # exercise,\n        sqlitedict = __import__(\"sqlitedict\")\n        # verify,\n        self.assertIn('pickle', sys.modules.keys())\n        self.assertIs(sqlitedict.dumps, sys.modules['pickle'].dumps)\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_temp_db.py",
      "content": "#!/usr/bin/env python\n# -*- coding: utf-8 -*-\n#\n# This code is distributed under the terms and conditions\n# from the Apache License, Version 2.0\nimport unittest\nimport sqlitedict\n\nfrom sys import version_info\nmajor_version = version_info[0]\n\n\nclass TempSqliteDictTest(unittest.TestCase):\n\n    def setUp(self):\n        self.d = sqlitedict.SqliteDict()\n\n    def tearDown(self):\n        self.d.close()\n\n    def test_create_sqlitedict(self):\n        ''' test_create_sqlitedict\n        '''\n        self.assertIsInstance(self.d, sqlitedict.SqliteDict)\n        self.assertEqual(dict(self.d), {})\n        self.assertEqual(list(self.d), [])\n        self.assertEqual(len(self.d), 0)\n\n    def test_assign_values(self):\n        ''' test_assign_values\n        '''\n        self.d['abc'] = 'edf'\n        self.assertEqual(self.d['abc'], 'edf')\n        self.assertEqual(len(self.d), 1)\n\n    def test_clear_data(self):\n        ''' test_clear_data\n        '''\n        self.d.update(a=1, b=2, c=3)\n        self.assertEqual(len(self.d), 3)\n        self.d.clear()\n        self.assertEqual(len(self.d), 0)\n\n    def test_manage_one_record(self):\n        ''' test_manage_one_record\n        '''\n        self.d['abc'] = 'rsvp' * 100\n        self.assertEqual(self.d['abc'], 'rsvp' * 100)\n        self.d['abc'] = 'lmno'\n        self.assertEqual(self.d['abc'], 'lmno')\n        self.assertEqual(len(self.d), 1)\n        del self.d['abc']\n        self.assertEqual(len(self.d), 0)\n        self.assertTrue(not self.d)\n\n    def test_manage_few_records(self):\n        ''' test_manage_few_records\n        '''\n        self.d['abc'] = 'lmno'\n        self.d['xyz'] = 'pdq'\n        self.assertEqual(len(self.d), 2)\n        if major_version == 2:\n            self.assertEqual(list(self.d.iteritems()), [('abc', 'lmno'), ('xyz', 'pdq')])\n        self.assertEqual(list(self.d.items()), [('abc', 'lmno'), ('xyz', 'pdq')])\n        self.assertEqual(list(self.d.values()), ['lmno', 'pdq'])\n        self.assertEqual(list(self.d.keys()), ['abc', 'xyz'])\n        self.assertEqual(list(self.d), ['abc', 'xyz'])\n\n    def test_update_records(self):\n        ''' test_update_records\n        '''\n        self.d.update([('v', 'w')], p='x', q='y', r='z')\n        self.assertEqual(len(self.d), 4)\n        # As far as I know dicts does not need to return\n        # the elements in a specified order (sort() is required )\n        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n        self.assertEqual(sorted(list(self.d)), sorted(['q', 'p', 'r', 'v']))\n\n    def test_handling_errors(self):\n        ''' test_handling_errors\n        '''\n        def get_value(d, k):\n            return d[k]\n\n        def remove_nonexists(d, k):\n            del d[k]\n\n        with self.assertRaises(KeyError):\n            remove_nonexists(self.d, 'abc')\n        with self.assertRaises(KeyError):\n            get_value(self.d, 'abc')\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_autocommit.py",
      "content": "import os\nimport sys\n\nimport sqlitedict\n\n\ndef test():\n    \"Verify autocommit just before program exits.\"\n    assert os.system('env PYTHONPATH=. %s tests/autocommit.py' % sys.executable) == 0\n    # The above script relies on the autocommit feature working correctly.\n    # Now, let's check if it actually worked.\n    d = sqlitedict.SqliteDict('tests/db/autocommit.sqlite')\n    for i in range(1000):\n        assert d[i] == i, \"actual: %s expected: %s\" % (d[i], i)\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_core.py",
      "content": "# std imports\nimport json\nimport unittest\nimport tempfile\nimport os\nfrom unittest.mock import patch\n\n# local\nimport sqlitedict\nfrom sqlitedict import SqliteDict\nfrom test_temp_db import TempSqliteDictTest\nfrom accessories import norm_file\n\n\nclass SqliteMiscTest(unittest.TestCase):\n\n    def test_with_statement(self):\n        \"\"\"Verify using sqlitedict as a contextmanager . \"\"\"\n        with SqliteDict() as d:\n            self.assertTrue(isinstance(d, SqliteDict))\n            self.assertEqual(dict(d), {})\n            self.assertEqual(list(d), [])\n            self.assertEqual(len(d), 0)\n\n    def test_reopen_conn(self):\n        \"\"\"Verify using a contextmanager that a connection can be reopened.\"\"\"\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        db = SqliteDict(filename=fname)\n        with db:\n            db['key'] = 'value'\n            db.commit()\n        with db:\n            db['key'] = 'value'\n            db.commit()\n\n    def test_as_str(self):\n        \"\"\"Verify SqliteDict.__str__().\"\"\"\n        # given,\n        db = SqliteDict()\n        # exercise\n        db.__str__()\n        # test when db closed\n        db.close()\n        db.__str__()\n\n    def test_as_repr(self):\n        \"\"\"Verify SqliteDict.__repr__().\"\"\"\n        # given,\n        db = SqliteDict()\n        # exercise\n        db.__repr__()\n\n    def test_directory_notfound(self):\n        \"\"\"Verify RuntimeError: directory does not exist.\"\"\"\n        # given: a non-existent directory,\n        folder = tempfile.mkdtemp(prefix='sqlitedict-test')\n        os.rmdir(folder)\n        # exercise,\n        with self.assertRaises(RuntimeError):\n            SqliteDict(filename=os.path.join(folder, 'nonexistent'))\n\n    def test_commit_nonblocking(self):\n        \"\"\"Coverage for non-blocking commit.\"\"\"\n        # given,\n        with SqliteDict(autocommit=True) as d:\n            # exercise: the implicit commit is nonblocking\n            d['key'] = 'value'\n            d.commit(blocking=False)\n\n    def test_cancel_iterate(self):\n        import time\n\n        class EndlessKeysIterator:\n            def __init__(self) -> None:\n                self.value = 0\n\n            def __iter__(self):\n                return self\n\n            def __next__(self):\n                self.value += 1\n                return [self.value]\n\n        with patch('sqlitedict.sqlite3') as mock_sqlite3:\n            ki = EndlessKeysIterator()\n            cursor = mock_sqlite3.connect().cursor()\n            cursor.__iter__.return_value = ki\n\n            with SqliteDict(autocommit=True) as d:\n                for i, k in enumerate(d.keys()):\n                    assert i + 1 == k\n                    if k > 100:\n                        break\n                assert ki.value > 101\n\n                # Release GIL, let background threads run.\n                # Don't use gc.collect because this is simulate user code.\n                time.sleep(0.01)\n\n                current = ki.value\n                time.sleep(1)\n                assert current == ki.value, 'Will not read more after iterate stop'\n\n\nclass NamedSqliteDictCreateOrReuseTest(TempSqliteDictTest):\n    \"\"\"Verify default flag='c', and flag='n' of SqliteDict().\"\"\"\n\n    def test_default_reuse_existing_flag_c(self):\n        \"\"\"Re-opening of a database does not destroy it.\"\"\"\n        # given,\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        orig_db = SqliteDict(filename=fname)\n        orig_db['key'] = 'value'\n        orig_db.commit()\n        orig_db.close()\n\n        next_db = SqliteDict(filename=fname)\n        self.assertIn('key', next_db.keys())\n        self.assertEqual(next_db['key'], 'value')\n\n    def test_overwrite_using_flag_n(self):\n        \"\"\"Re-opening of a database with flag='c' destroys it all.\"\"\"\n        # given,\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        orig_db = SqliteDict(filename=fname, tablename='sometable')\n        orig_db['key'] = 'value'\n        orig_db.commit()\n        orig_db.close()\n\n        # verify,\n        next_db = SqliteDict(filename=fname, tablename='sometable', flag='n')\n        self.assertNotIn('key', next_db.keys())\n\n    def test_unrecognized_flag(self):\n\n        def build_with_bad_flag():\n            fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n            SqliteDict(filename=fname, flag='FOO')\n\n        with self.assertRaises(RuntimeError):\n            build_with_bad_flag()\n\n    def test_readonly(self):\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        orig_db = SqliteDict(filename=fname)\n        orig_db['key'] = 'value'\n        orig_db['key_two'] = 2\n        orig_db.commit()\n        orig_db.close()\n\n        readonly_db = SqliteDict(filename=fname, flag='r')\n        self.assertTrue(readonly_db['key'] == 'value')\n        self.assertTrue(readonly_db['key_two'] == 2)\n\n        def attempt_write():\n            readonly_db['key'] = ['new_value']\n\n        def attempt_update():\n            readonly_db.update(key='value2', key_two=2.1)\n\n        def attempt_delete():\n            del readonly_db['key']\n\n        def attempt_clear():\n            readonly_db.clear()\n\n        def attempt_terminate():\n            readonly_db.terminate()\n\n        attempt_funcs = [attempt_write, attempt_update, attempt_delete, attempt_clear, attempt_terminate]\n\n        for func in attempt_funcs:\n            with self.assertRaises(RuntimeError):\n                func()\n\n    def test_readonly_table(self):\n        \"\"\"\n        Read-only access on a non-existent tablename should raise RuntimeError,\n        and not create a new (empty) table.\n        \"\"\"\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        dummy_tablename = 'table404'\n        orig_db = SqliteDict(filename=fname)\n        orig_db['key'] = 'value'\n        orig_db['key_two'] = 2\n        orig_db.commit()\n        orig_db.close()\n\n        self.assertFalse(dummy_tablename in SqliteDict.get_tablenames(fname))\n\n        with self.assertRaises(RuntimeError):\n            SqliteDict(filename=fname, tablename=dummy_tablename, flag='r')\n\n        self.assertFalse(dummy_tablename in SqliteDict.get_tablenames(fname))\n\n    def test_irregular_tablenames(self):\n        \"\"\"Irregular table names need to be quoted\"\"\"\n        def __test_irregular_tablenames(tablename):\n            filename = ':memory:'\n            db = SqliteDict(filename, tablename=tablename)\n            db['key'] = 'value'\n            db.commit()\n            self.assertEqual(db['key'], 'value')\n            db.close()\n\n        __test_irregular_tablenames('9nine')\n        __test_irregular_tablenames('outer space')\n        __test_irregular_tablenames('table with a \"quoted\" name')\n        __test_irregular_tablenames(\"table with a \\\"quoted \\xe1cute\\\" name\")\n\n    def test_overwrite_using_flag_w(self):\n        \"\"\"Re-opening of a database with flag='w' destroys only the target table.\"\"\"\n        # given,\n        fname = norm_file('tests/db/sqlitedict-override-test.sqlite')\n        orig_db_1 = SqliteDict(filename=fname, tablename='one')\n        orig_db_1['key'] = 'value'\n        orig_db_1.commit()\n        orig_db_1.close()\n\n        orig_db_2 = SqliteDict(filename=fname, tablename='two')\n        orig_db_2['key'] = 'value'\n        orig_db_2.commit()\n        orig_db_2.close()\n\n        # verify, when re-opening table space 'one' with flag='2', we destroy\n        # its contents.  However, when re-opening table space 'two' with\n        # default flag='r', its contents remain.\n        next_db_1 = SqliteDict(filename=fname, tablename='one', flag='w')\n        self.assertNotIn('key', next_db_1.keys())\n\n        next_db_2 = SqliteDict(filename=fname, tablename='two')\n        self.assertIn('key', next_db_2.keys())\n\n\nclass SqliteDictTerminateTest(unittest.TestCase):\n\n    def test_terminate_instead_close(self):\n        ''' make terminate() instead of close()\n        '''\n        d = sqlitedict.open('tests/db/sqlitedict-terminate.sqlite')\n        d['abc'] = 'def'\n        d.commit()\n        self.assertEqual(d['abc'], 'def')\n        d.terminate()\n        self.assertFalse(os.path.isfile('tests/db/sqlitedict-terminate.sqlite'))\n\n\nclass SqliteDictTerminateFailTest(unittest.TestCase):\n    \"\"\"Provide Coverage for SqliteDict.terminate().\"\"\"\n\n    def setUp(self):\n        self.fname = norm_file('tests/db-permdenied/sqlitedict.sqlite')\n        self.db = SqliteDict(filename=self.fname)\n        os.chmod(self.fname, 0o000)\n        os.chmod(os.path.dirname(self.fname), 0o000)\n\n    def tearDown(self):\n        os.chmod(os.path.dirname(self.fname), 0o700)\n        os.chmod(self.fname, 0o600)\n        os.unlink(self.fname)\n        os.rmdir(os.path.dirname(self.fname))\n\n    def test_terminate_cannot_delete(self):\n        # exercise,\n        self.db.terminate()  # deletion failed, but no exception raised!\n\n        # verify,\n        os.chmod(os.path.dirname(self.fname), 0o700)\n        os.chmod(self.fname, 0o600)\n        self.assertTrue(os.path.exists(self.fname))\n\n\nclass SqliteDictJsonSerializationTest(unittest.TestCase):\n    def setUp(self):\n        self.fname = norm_file('tests/db-json/sqlitedict.sqlite')\n        self.db = SqliteDict(\n            filename=self.fname, tablename='test', encode=json.dumps, decode=json.loads\n        )\n\n    def tearDown(self):\n        self.db.close()\n        os.unlink(self.fname)\n        os.rmdir(os.path.dirname(self.fname))\n\n    def get_json(self, key):\n        return self.db.conn.select_one('SELECT value FROM test WHERE key = ?', (self.db.encode_key(key),))[0]\n\n    def test_int(self):\n        self.db['test'] = -42\n        assert self.db['test'] == -42\n        assert self.get_json('test') == '-42'\n\n    def test_str(self):\n        test_str = u'Test \\u30c6\\u30b9\\u30c8'\n        self.db['test'] = test_str\n        assert self.db['test'] == test_str\n        assert self.get_json('test') == r'\"Test \\u30c6\\u30b9\\u30c8\"'\n\n    def test_bool(self):\n        self.db['test'] = False\n        assert self.db['test'] is False\n        assert self.get_json('test') == 'false'\n\n    def test_none(self):\n        self.db['test'] = None\n        assert self.db['test'] is None\n        assert self.get_json('test') == 'null'\n\n    def test_complex_struct(self):\n        test_value = {\n            'version': 2.5,\n            'items': ['one', 'two'],\n        }\n        self.db['test'] = test_value\n        assert self.db['test'] == test_value\n        assert self.get_json('test') == json.dumps(test_value)\n\n\nclass TablenamesTest(unittest.TestCase):\n    def tearDown(self):\n        for f in ('tablenames-test-1.sqlite', 'tablenames-test-2.sqlite'):\n            path = norm_file(os.path.join('tests/db', f))\n            if os.path.isfile(path):\n                os.unlink(path)\n\n    def test_tablenames_unnamed(self):\n        fname = norm_file('tests/db/tablenames-test-1.sqlite')\n        SqliteDict(fname)\n        self.assertEqual(SqliteDict.get_tablenames(fname), ['unnamed'])\n\n    def test_tablenams_named(self):\n        fname = norm_file('tests/db/tablenames-test-2.sqlite')\n        with SqliteDict(fname, tablename='table1'):\n            self.assertEqual(SqliteDict.get_tablenames(fname), ['table1'])\n        with SqliteDict(fname, tablename='table2'):\n            self.assertEqual(SqliteDict.get_tablenames(fname), ['table1', 'table2'])\n\n        tablenames = SqliteDict.get_tablenames('tests/db/tablenames-test-2.sqlite')\n        self.assertEqual(tablenames, ['table1', 'table2'])\n\n\nclass SqliteDictKeySerializationTest(unittest.TestCase):\n    def setUp(self):\n        self.fname = norm_file('tests/db-encode-key/sqlitedict.sqlite')\n        self.db = SqliteDict(\n            filename=self.fname, tablename='test',\n            encode_key=sqlitedict.encode_key, decode_key=sqlitedict.decode_key,\n        )\n\n    def test_nonstr_keys(self):\n        self.db['test'] = -42\n        assert self.db['test'] == -42\n        self.db[(0, 1, 2)] = 17\n        assert self.db[(0, 1, 2)] == 17\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_named_db.py",
      "content": "import sqlitedict\nfrom test_temp_db import TempSqliteDictTest\nfrom accessories import norm_file\n\n\nclass InMemorySqliteDictTest(TempSqliteDictTest):\n\n    def setUp(self):\n        self.d = sqlitedict.SqliteDict(filename=':memory:', autocommit=True)\n\n    def tearDown(self):\n        self.d.terminate()\n\n\nclass NamedSqliteDictTest(TempSqliteDictTest):\n\n    def setUp(self):\n        db = norm_file('tests/db/sqlitedict-with-def.sqlite')\n        self.d = sqlitedict.SqliteDict(filename=db)\n\n\nclass CreateNewSqliteDictTest(TempSqliteDictTest):\n\n    def setUp(self):\n        db = norm_file('tests/db/sqlitedict-with-n-flag.sqlite')\n        self.d = sqlitedict.SqliteDict(filename=db, flag=\"n\")\n\n    def tearDown(self):\n        self.d.terminate()\n\n\nclass StartsWithEmptySqliteDictTest(TempSqliteDictTest):\n\n    def setUp(self):\n        db = norm_file('tests/db/sqlitedict-with-w-flag.sqlite')\n        self.d = sqlitedict.SqliteDict(filename=db, flag=\"w\")\n\n    def tearDown(self):\n        self.d.terminate()\n\n\nclass SqliteDictAutocommitTest(TempSqliteDictTest):\n\n    def setUp(self):\n        db = norm_file('tests/db/sqlitedict-autocommit.sqlite')\n        self.d = sqlitedict.SqliteDict(filename=db, autocommit=True)\n\n    def tearDown(self):\n        self.d.terminate()\n"
    },
    {
      "path": "piskvorky_sqlitedict/tests/accessories.py",
      "content": "\"\"\"Accessories for test cases.\"\"\"\nimport os\n\n\ndef norm_file(fname):\n    \"\"\"Normalize test filename, creating a directory path to it if necessary\"\"\"\n    fname = os.path.abspath(fname)\n    dirname = os.path.dirname(fname)\n    if not os.path.exists(dirname):\n        os.makedirs(dirname)\n    return fname\n"
    },
    {
      "path": "piskvorky_sqlitedict/release/summarize_pr.py",
      "content": "#!/usr/bin/env python\nimport json\nimport sys\nimport urllib.request\n\n\ndef copy_to_clipboard(text):\n    try:\n        import pyperclip\n    except ImportError:\n        print('pyperclip <https://pypi.org/project/pyperclip/> is missing.', file=sys.stderr)\n        print('copy-paste the following text manually:', file=sys.stderr)\n        print('  ' + text, file=sys.stderr)\n    else:\n        pyperclip.copy(text)\n\n\nfor prid in sys.argv[1:]:\n    url = \"https://api.github.com/repos/RaRe-Technologies/sqlitedict/pulls/%s\" % prid\n    with urllib.request.urlopen(url) as fin:\n        prinfo = json.load(fin)\n\n    prinfo['user_login'] = prinfo['user']['login']\n    prinfo['user_html_url'] = prinfo['user']['html_url']\n    text = '- %(title)s (PR [#%(number)s](%(html_url)s), [@%(user_login)s](%(user_html_url)s))' % prinfo\n    print(text)\n"
    }
  ],
  "ErrorMessage": "======================================================================\nERROR: test_terminate_cannot_delete (test_core.SqliteDictTerminateFailTest)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_core.py\", line 254, in setUp\n    self.db = SqliteDict(filename=self.fname)\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 229, in __init__\n    self.conn.execute(MAKE_TABLE)\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 616, in execute\n    self.check_raise_error()\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 606, in check_raise_error\n    reraise(e_type, e_value, e_tb)\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 46, in reraise\n    raise value.with_traceback(tb)\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 474, in _connect\n    conn = sqlite3.connect(self.filename, check_same_thread=False)\nsqlite3.OperationalError: unable to open database file\n\n======================================================================\nFAIL: test_update_records (test_core.NamedSqliteDictCreateOrReuseTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_temp_db.TempSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.CreateNewSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.InMemorySqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.NamedSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.SqliteDictAutocommitTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.StartsWithEmptySqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_temp_db.TempSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_temp_db.TempSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n----------------------------------------------------------------------\nRan 88 tests in 1.115s\n\nFAILED (failures=9, errors=1)",
  "Patch": "--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -46,8 +46,8 @@\n         '''\n         self.d['abc'] = 'rsvp' * 100\n         self.assertEqual(self.d['abc'], 'rsvp' * 100)\n-        self.d['abc'] = 100\n-        self.assertEqual(self.d['abc'], 100)\n+        self.d['abc'] = 'lmno'\n+        self.assertEqual(self.d['abc'], 'lmno')\n         self.assertEqual(len(self.d), 1)\n         del self.d['abc']\n         self.assertEqual(len(self.d), 0)\n@@ -73,8 +73,8 @@\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n-        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        self.assertEqual(sorted(list(self.d)), sorted(['q', 'p', 'r', 'v']))\n \n     def test_handling_errors(self):\n         ''' test_handling_errors\n--- a/piskvorky_sqlitedict/tests/test_core.py\n+++ b/piskvorky_sqlitedict/tests/test_core.py\n@@ -130,7 +130,6 @@\n         # verify,\n         next_db = SqliteDict(filename=fname, tablename='sometable', flag='n')\n         self.assertNotIn('key', next_db.keys())\n-        self.assertNotIn('value', next_db.values())\n \n     def test_unrecognized_flag(self):\n \n",
  "BuggyCodeLocation": [
    {
      "file": "piskvorky_sqlitedict/tests/test_core.py",
      "function": null,
      "content_all": {
        "133": "        self.assertNotIn('value', next_db.values())\n"
      },
      "content_change": {
        "133": "        self.assertNotIn('value', next_db.values())\n"
      }
    },
    {
      "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
      "function": {
        "44": "test_manage_one_record"
      },
      "content_all": {
        "46": "        '''\n",
        "47": "        self.d['abc'] = 'rsvp' * 100\n",
        "48": "        self.assertEqual(self.d['abc'], 'rsvp' * 100)\n",
        "49": "        self.d['abc'] = 100\n",
        "50": "        self.assertEqual(self.d['abc'], 100)\n",
        "51": "        self.assertEqual(len(self.d), 1)\n",
        "52": "        del self.d['abc']\n",
        "53": "        self.assertEqual(len(self.d), 0)\n"
      },
      "content_change": {
        "49": "        self.d['abc'] = 100\n",
        "50": "        self.assertEqual(self.d['abc'], 100)\n"
      }
    },
    {
      "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
      "function": {
        "69": "test_update_records"
      },
      "content_all": {
        "73": "        self.assertEqual(len(self.d), 4)\n",
        "74": "        # As far as I know dicts does not need to return\n",
        "75": "        # the elements in a specified order (sort() is required )\n",
        "76": "        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n"
      },
      "content_change": {
        "76": "        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n"
      }
    },
    {
      "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
      "function": null,
      "content_all": {
        "77": "        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n"
      },
      "content_change": {
        "77": "        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n"
      }
    }
  ],
  "Issue": {
    "title": "Inconsistent Test Behavior and Assertion Error in SqliteDict Tests",
    "description": "### Issue Description\nCertain tests in the `piskvorky_sqlitedict` library are currently failing due to inconsistencies in values and test assertions. Specifically, when managing dictionary records, the values 'abc' and 100 are causing assertion errors. Furthermore, the tests for checking the integrity of dictionary items and their sorted order are not functioning as intended.\n\n### Impact\nThe faulty tests lead to unreliable test outcomes, which can mask actual issues in the `SqliteDict` implementation. This undermines developer confidence and affects CI/CD pipelines, causing unnecessary delays and complications.\n\n### Steps to Reproduce\n1. Run the existing tests in `piskvorky_sqlitedict/tests/test_temp_db.py`.\n2. Observe failures in tests related to managing individual records and sorting of dictionary items.\n3. Notice the incorrect assertion related to checking values in `piskvorky_sqlitedict/tests/test_core.py`.\n\n### Expected Behavior\nTests should consistently pass without assertion errors, reflecting the actual state and contents of `SqliteDict` accurately.\n\n### Actual Behavior\n- Assertion Error when changing value from 'abc' to 100.\n- Sorting and value checking tests fail due to incorrect assertions.\n- Redundant check for non-existent 'value' in `next_db.values()` causes test failures.\n\n### Possible Solutions\n- Ensuring values are consistent and accurately reflected in tests.\n- Correcting assertions to align with the expected behavior of `SqliteDict`.\n- Removing redundant checks in `piskvorky_sqlitedict/tests/test_core.py` to prevent false negatives during test runs.\n\n### Additional Information\nThis issue aims to improve the reliability and consistency of unit tests, providing a robust foundation for further development and maintenance of the `SqliteDict` library.",
    "explanation": "### Summary of the Issue\n\nThe issue at hand involves failing tests in the `piskvorky_sqlitedict` library, specifically concerning the management of dictionary records and the integrity checks of dictionary items. The failing tests were raising assertion errors when the dictionary values changed from strings to integers. Additionally, tests that checked the order and consistency of dictionary items were not functioning as intended, leading to unreliable test outcomes. These faulty tests erode developer confidence and disrupt CI/CD pipelines, resulting in delays and complications in the development process.\n\n### Detailed Commit Analysis\n\nThe commit provided addresses the aforementioned issues in multiple parts of the test suite. Here's a summary of the key aspects covered by the commit:\n\n1. **Changing Values in Tests (`test_temp_db.py`)**:\n    - The tests were modified to handle string values consistently instead of changing a dictionary value from a string (`'abc'`) to an integer (`100`). This change eliminates the assertion error caused by the type mismatch:\n      - Instead of setting a value to `100`, it was changed to another string (`'lmno'`).\n\n2. **Sorted Dictionary Assertion (`test_temp_db.py`)**:\n   - Modified the assertions to properly compare the sorted representation of `d.items()` and the list of keys to guarantee accurate sorting and comparison.\n\n3. **Redundant Check Removal (`test_core.py`)**:\n   - Removed a redundant assertion that checked for a non-existent value `'value'` in the dictionary’s values, which was causing test failures. This check was logically incorrect and unnecessary.\n\n### Explanation of How the Commit Solves the Issue\n\n**Consistent Value Types:**\n- One of the primary causes of the issue was the inconsistency in value types during dictionary operations, wherein the test altered a dictionary entry from a string to an integer. Since dictionaries expect consistent key-value types for meaningful operations, this abrupt change was generating assertion errors. By ensuring that values remain consistent as strings within the test, it removes the type mismatch and resultant errors. This enhances the reliability of the `SqliteDict`'s behavior under test conditions.\n\n**Proper Sorting Assertion:**\n- Another significant part of the problem was the improper assertion for sorted dictionary items. The original comparison did not account for dictionary item pairs. By refactoring the assertions to compare sorted items and keys separately, the commit ensures the validations correctly reflect the expected order and integrity of dictionary entries. This change guarantees that the tests validate the order of dictionary items accurately.\n\n**Removing Redundant Checks:**\n- The redundant check for a non-existent `'value'` in `next_db.values()` was unnecessary and logically flawed, leading to false test failures. By removing this check, the test assertions are now cleaner and focus on relevant and valid conditions, reducing false negatives and improving overall test accuracy.\n\n### Solution Recap\n\nTo summarize, the commit resolves the issue by:\n\n1. **Maintaining Consistent Value Types:** Ensuring the dictionary values remain as consistent types (in this case, strings) throughout operations within the tests.\n2. **Correct Assertions for Sorting:** Properly validating the sorted state of dictionary entries by checking sorted items and keys, ensuring accurate tests for dictionary content and order.\n3. **Eliminating Redundant Checks:** Removing unnecessary and logically flawed assertions that were causing false test failures.\n\nThese changes together address the root causes of the test failures, resulting in more stable and reliable test outcomes, fostering better confidence in the `SqliteDict` library's functionality and improving the efficiency of CI/CD pipelines."
  },
  "Explain": "### Summary of the Issue\n\nThe issue at hand involves failing tests in the `piskvorky_sqlitedict` library, specifically concerning the management of dictionary records and the integrity checks of dictionary items. The failing tests were raising assertion errors when the dictionary values changed from strings to integers. Additionally, tests that checked the order and consistency of dictionary items were not functioning as intended, leading to unreliable test outcomes. These faulty tests erode developer confidence and disrupt CI/CD pipelines, resulting in delays and complications in the development process.\n\n### Detailed Commit Analysis\n\nThe commit provided addresses the aforementioned issues in multiple parts of the test suite. Here's a summary of the key aspects covered by the commit:\n\n1. **Changing Values in Tests (`test_temp_db.py`)**:\n    - The tests were modified to handle string values consistently instead of changing a dictionary value from a string (`'abc'`) to an integer (`100`). This change eliminates the assertion error caused by the type mismatch:\n      - Instead of setting a value to `100`, it was changed to another string (`'lmno'`).\n\n2. **Sorted Dictionary Assertion (`test_temp_db.py`)**:\n   - Modified the assertions to properly compare the sorted representation of `d.items()` and the list of keys to guarantee accurate sorting and comparison.\n\n3. **Redundant Check Removal (`test_core.py`)**:\n   - Removed a redundant assertion that checked for a non-existent value `'value'` in the dictionary’s values, which was causing test failures. This check was logically incorrect and unnecessary.\n\n### Explanation of How the Commit Solves the Issue\n\n**Consistent Value Types:**\n- One of the primary causes of the issue was the inconsistency in value types during dictionary operations, wherein the test altered a dictionary entry from a string to an integer. Since dictionaries expect consistent key-value types for meaningful operations, this abrupt change was generating assertion errors. By ensuring that values remain consistent as strings within the test, it removes the type mismatch and resultant errors. This enhances the reliability of the `SqliteDict`'s behavior under test conditions.\n\n**Proper Sorting Assertion:**\n- Another significant part of the problem was the improper assertion for sorted dictionary items. The original comparison did not account for dictionary item pairs. By refactoring the assertions to compare sorted items and keys separately, the commit ensures the validations correctly reflect the expected order and integrity of dictionary entries. This change guarantees that the tests validate the order of dictionary items accurately.\n\n**Removing Redundant Checks:**\n- The redundant check for a non-existent `'value'` in `next_db.values()` was unnecessary and logically flawed, leading to false test failures. By removing this check, the test assertions are now cleaner and focus on relevant and valid conditions, reducing false negatives and improving overall test accuracy.\n\n### Solution Recap\n\nTo summarize, the commit resolves the issue by:\n\n1. **Maintaining Consistent Value Types:** Ensuring the dictionary values remain as consistent types (in this case, strings) throughout operations within the tests.\n2. **Correct Assertions for Sorting:** Properly validating the sorted state of dictionary entries by checking sorted items and keys, ensuring accurate tests for dictionary content and order.\n3. **Eliminating Redundant Checks:** Removing unnecessary and logically flawed assertions that were causing false test failures.\n\nThese changes together address the root causes of the test failures, resulting in more stable and reliable test outcomes, fostering better confidence in the `SqliteDict` library's functionality and improving the efficiency of CI/CD pipelines.",
  "Source": "Human",
  "Token": 1476,
  "Command": [
    "python -m unittest discover -s tests"
  ],
  "FilteredCode": [
    {
      "path": "piskvorky_sqlitedict/tests/test_temp_db.py",
      "content": "1 #!/usr/bin/env python\n2 # -*- coding: utf-8 -*-\n3 #\n4 # This code is distributed under the terms and conditions\n5 # from the Apache License, Version 2.0\n6 import unittest\n7 import sqlitedict\n8 \n9 from sys import version_info\n10 major_version = version_info[0]\n11 \n12 \n13 class TempSqliteDictTest(unittest.TestCase):\n14 \n15     def setUp(self):\n16         self.d = sqlitedict.SqliteDict()\n17 \n18     def tearDown(self):\n19         self.d.close()\n20 \n21     def test_create_sqlitedict(self):\n22         ''' test_create_sqlitedict\n23         '''\n24         self.assertIsInstance(self.d, sqlitedict.SqliteDict)\n25         self.assertEqual(dict(self.d), {})\n26         self.assertEqual(list(self.d), [])\n27         self.assertEqual(len(self.d), 0)\n28 \n29     def test_assign_values(self):\n30         ''' test_assign_values\n31         '''\n32         self.d['abc'] = 'edf'\n33         self.assertEqual(self.d['abc'], 'edf')\n34         self.assertEqual(len(self.d), 1)\n35 \n36     def test_clear_data(self):\n37         ''' test_clear_data\n38         '''\n39         self.d.update(a=1, b=2, c=3)\n40         self.assertEqual(len(self.d), 3)\n41         self.d.clear()\n42         self.assertEqual(len(self.d), 0)\n43 \n44     def test_manage_one_record(self):\n45         ''' test_manage_one_record\n46         '''\n47         self.d['abc'] = 'rsvp' * 100\n48         self.assertEqual(self.d['abc'], 'rsvp' * 100)\n49         self.d['abc'] = 100\n50         self.assertEqual(self.d['abc'], 100)\n51         self.assertEqual(len(self.d), 1)\n52         del self.d['abc']\n53         self.assertEqual(len(self.d), 0)\n54         self.assertTrue(not self.d)\n55 \n56     def test_manage_few_records(self):\n57         ''' test_manage_few_records\n58         '''\n59         self.d['abc'] = 'lmno'\n60         self.d['xyz'] = 'pdq'\n61         self.assertEqual(len(self.d), 2)\n62         if major_version == 2:\n63             self.assertEqual(list(self.d.iteritems()), [('abc', 'lmno'), ('xyz', 'pdq')])\n64         self.assertEqual(list(self.d.items()), [('abc', 'lmno'), ('xyz', 'pdq')])\n65         self.assertEqual(list(self.d.values()), ['lmno', 'pdq'])\n66         self.assertEqual(list(self.d.keys()), ['abc', 'xyz'])\n67         self.assertEqual(list(self.d), ['abc', 'xyz'])\n68 \n69     def test_update_records(self):\n70         ''' test_update_records\n71         '''\n72         self.d.update([('v', 'w')], p='x', q='y', r='z')\n73         self.assertEqual(len(self.d), 4)\n74         # As far as I know dicts does not need to return\n75         # the elements in a specified order (sort() is required )\n76         self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n77         self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n78 \n79     def test_handling_errors(self):\n80         ''' test_handling_errors\n81         '''\n82         def get_value(d, k):\n83             return d[k]\n84 \n85         def remove_nonexists(d, k):\n86             del d[k]\n87 \n88         with self.assertRaises(KeyError):\n89             remove_nonexists(self.d, 'abc')\n90         with self.assertRaises(KeyError):\n91             get_value(self.d, 'abc')"
    },
    {
      "path": "piskvorky_sqlitedict/sqlitedict.py",
      "content": "1 #!/usr/bin/env python\n2 # -*- coding: utf-8 -*-\n3 #\n4 # This code is distributed under the terms and conditions\n5 # from the Apache License, Version 2.0\n6 #\n7 # http://opensource.org/licenses/apache2.0.php\n8 #\n9 # This code was inspired by:\n10 #  * http://code.activestate.com/recipes/576638-draft-for-an-sqlite3-based-dbm/\n11 #  * http://code.activestate.com/recipes/526618/\n12 \n13 \"\"\"\n14 A lightweight wrapper around Python's sqlite3 database, with a dict-like interface\n15 and multi-thread access support::\n16 \n17 >>> mydict = SqliteDict('some.db', autocommit=True) # the mapping will be persisted to file `some.db`\n18 >>> mydict['some_key'](...truncated)"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_core.py",
      "content": "1 # std imports\n2 import json\n3 import unittest\n4 import tempfile\n5 import os\n6 from unittest.mock import patch\n7 \n8 # local\n9 import sqlitedict\n10 from sqlitedict import SqliteDict\n11 from test_temp_db import TempSqliteDictTest\n12 from accessories import norm_file\n13 \n14 \n15 class SqliteMiscTest(unittest.TestCase):\n16 \n17     def test_with_statement(self):\n18         \"\"\"Verify using sqlitedict as a contextmanager . \"\"\"\n19         with Sqlite(...truncated)"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_autocommit.py",
      "content": "1 import os\n2 import sys\n3 \n4 import sqlitedict\n5 \n6 \n7 def test():\n8     \"Verify autocommit just before program exits.\"\n9     assert os.system('env PYTHONPATH=. %s tests/autocommit.py' % sys.executable) == 0\n10     # The above script relies on the autocommit feature working correctly.\n11     # Now, let's check if it actually worked.\n12     d = sqlitedict.SqliteDict('tests/db/autocommit.sqlite')\n13     for i in range(1000):\n14         assert d[i] == i, \"actual: %s expected: %s\" % (d[i], i)"
    },
    {
      "path": "piskvorky_sqlitedict/tests/test_named_db.py",
      "content": "1 import sqlitedict\n2 from test_temp_db import TempSqliteDictTest\n3 from accessories import norm_file\n4 \n5 \n6 class (...truncated)"
    },
    {
      "path": "piskvorky_sqlitedict/setup.py",
      "content": "1 #!/usr/bin/env python\n2 # -*- coding: utf-8 -*-\n3 #\n4 # Th(...truncated)"
    }
  ],
  "TokenAll": 13034,
  "FilteredLevel": 1500,
  "Results": {
    "model": "GPT-4o",
    "Difficulty": "Medium",
    "issue_origin": {
      "title": "Incorrect Assertion in test_update_records",
      "description": "The test 'test_update_records' in 'piskvorky_sqlitedict/tests/test_temp_db.py' contains an incorrect assertion:\nself.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nThis line attempts to sort and compare keys with key-value pairs which will raise a TypeError due to incompatible types. The correct comparison should be only between keys or only between key-value pairs.",
      "explanation": "### Issue Summary\nThe issue revolves around an incorrect assertion in the `test_update_records` test case found in the file `piskvorky_sqlitedict/tests/test_temp_db.py`. The problematic line is:\n\n```python\nself.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n```\n\nThis line attempts to sort and compare the dictionary `self.d`, which contains key-value pairs, with a list of key-value pairs. Sorting and comparing a dictionary's keys with key-value pairs will raise a `TypeError` due to incompatible types.\n\n### Detailed Content of the Commit\nThe commit should fix this incorrect assertion by comparing only compatible types. Here's what an appropriate fix might look like:\n\n1. **Change the incorrect assertion line to compare only the keys:**\n    Replace:\n    ```python\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n    ```\n    with:\n    ```python\n    self.assertEqual(sorted(self.d.keys()), sorted(['q', 'p', 'r', 'v']))\n    ```\n\n2. **Add an assertion to compare key-value pairs accurately if necessary:**\n    If you need to compare both the keys and their values, you can add another assertion after sorting both sets of key-value pairs:\n    ```python\n    self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n    ```\n\n### Explanation of How the Commit Solves the Issue\n#### Original Incorrect Assertion\n- The original assertion `self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))` attempts to sort a `dict` directly and compare it with a list of tuples. In Python, you can't directly compare a dictionary to a list of tuples, as they are different types:\n  ```python\n  sorted(self.d) # Sorts only the keys of the dictionary.\n  sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]) # Sorts a list of tuples.\n  ```\n  This results in a mismatch due to comparing keys with key-value pairs, hence a `TypeError`.\n\n#### Corrective Action\n- **Comparing only the keys:** By changing the assertion to `self.assertEqual(sorted(self.d.keys()), sorted(['q', 'p', 'r', 'v']))`, the test now compares the sorted list of dictionary keys to another sorted list of expected keys. This ensures that the dictionary `self.d` contains the correct keys irrespective of the order:\n  ```python\n  sorted(self.d.keys())  # This gets sorted list of dictionary keys.\n  sorted(['q', 'p', 'r', 'v'])  # This sorts the expected list of keys.\n  ```\n\n- **Comparing key-value pairs accurately:** By adding `self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))`, the test now accurately compares the sorted list of dictionary items (key-value pairs) to the expected list of key-value pairs. This provides a robust check that both keys and values are correctly updated in the dictionary:\n  ```python\n  sorted(self.d.items())  # Sorts the list of dictionary key-value pairs.\n  sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')])  # Sorts the expected list of key-value pairs.\n  ```\n\n### Summary of the Fix\nThe commit modifies the `test_update_records` function to address the `TypeError` issue by:\n1. Changing the assertion to compare only the sorted dictionary keys against a sorted list of expected keys.\n2. Adding a second assertion to compare the sorted dictionary items (key-value pairs) against the expected list of key-value pairs if necessary.\n\nThese changes ensure the test will correctly verify the contents of the dictionary `self.d` without raising a `TypeError` due to incompatible type comparisons."
    },
    "issue_message": {
      "title": "Incorrect assertion in test_update_records",
      "description": "The test test_update_records in file piskvorky_sqlitedict/tests/test_temp_db.py is asserting that a sorted dictionary equals a sorted list of tuples which is not correct. The code line 'self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))' should be corrected to properly compare dictionary items.",
      "explanation": "### Summary of the Issue:\nThe test case `test_update_records` in the file `test_temp_db.py` is incorrectly asserting that a sorted dictionary is equal to a sorted list of tuples. The assertion is done at line 76: \n\n```python\nself.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n```\n\nThis line is comparing the sorted list of dictionary keys with a sorted list of tuples, which are inherently different data structures and result in mismatched assertions.\n\n### Detailed Content of the Commit:\nThe commit essentially addresses the incorrect assertion by changing the comparison to correctly compare the sorted dictionary items with the sorted list of tuples. The key part of the commit can be represented as follows:\n\n```diff\n- self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+ self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n```\n\n### Explanation of How the Commit Solves the Issue:\n1. **Nature of the Error**: The original assertion was comparing `sorted(self.d)` with `sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')])`. `sorted(self.d)` actually sorts the keys of the dictionary and results in a list of keys `['p', 'q', 'r', 'v']`. On the other hand, `sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')])` sorts the list of tuples based on the first item in each tuple, resulting in `[(‘p', 'x'), (‘q', 'y’), (‘r', 'z’), (‘v', 'w’)]`. Since these two lists are inherently different (`keys` vs `tuple pairs`), the test case fails.\n\n2. **Proper Comparison**: To correctly assert that the dictionary contains the expected key-value pairs, you need to compare items of the dictionary, not just the keys. `self.d.items()` provides a view of the dictionary’s items (key-value pairs) as a list of tuples. Thus, `sorted(self.d.items())` gives you a sorted list of the dictionary’s key-value pairs.\n\n3. **Application**: By changing the assertion to `self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))`, the test now correctly compares:\n   - The sorted dictionary items: `sorted(self.d.items()) -> [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]`\n   - With the sorted expected list: `sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')])`\n\n4. **Outcome**: Now, both lists represent the dictionary items, and when sorted, they will match correctly if `self.d` contains the correct key-value pairs as expected. This modification ensures that the test accurately verifies if the dictionary was updated with the correct records.\n\n### Summary Conclusion:\nThis commit resolves the issue by ensuring that the comparison in the `test_update_records` correctly asserts that the contents of the dictionary match the expected key-value pairs. It changes the assertion from comparing just the dictionary keys to comparing the dictionary items, thus properly validating the dictionary’s data."
    },
    "issue_ground": {
      "title": "Inconsistent Test Behavior and Assertion Error in SqliteDict Tests",
      "description": "### Issue Description\nCertain tests in the `piskvorky_sqlitedict` library are currently failing due to inconsistencies in values and test assertions. Specifically, when managing dictionary records, the values 'abc' and 100 are causing assertion errors. Furthermore, the tests for checking the integrity of dictionary items and their sorted order are not functioning as intended.\n\n### Impact\nThe faulty tests lead to unreliable test outcomes, which can mask actual issues in the `SqliteDict` implementation. This undermines developer confidence and affects CI/CD pipelines, causing unnecessary delays and complications.\n\n### Steps to Reproduce\n1. Run the existing tests in `piskvorky_sqlitedict/tests/test_temp_db.py`.\n2. Observe failures in tests related to managing individual records and sorting of dictionary items.\n3. Notice the incorrect assertion related to checking values in `piskvorky_sqlitedict/tests/test_core.py`.\n\n### Expected Behavior\nTests should consistently pass without assertion errors, reflecting the actual state and contents of `SqliteDict` accurately.\n\n### Actual Behavior\n- Assertion Error when changing value from 'abc' to 100.\n- Sorting and value checking tests fail due to incorrect assertions.\n- Redundant check for non-existent 'value' in `next_db.values()` causes test failures.\n\n### Possible Solutions\n- Ensuring values are consistent and accurately reflected in tests.\n- Correcting assertions to align with the expected behavior of `SqliteDict`.\n- Removing redundant checks in `piskvorky_sqlitedict/tests/test_core.py` to prevent false negatives during test runs.\n\n### Additional Information\nThis issue aims to improve the reliability and consistency of unit tests, providing a robust foundation for further development and maintenance of the `SqliteDict` library.",
      "explanation": "### Issue Summary\n\nThe `piskvorky_sqlitedict` library is experiencing a set of issues related to inconsistencies in values and test assertions within its unit tests. Specifically, problems have been identified when managing dictionary records (e.g., changing values from strings to integers), verifying the integrity and order of dictionary items, and redundant checks that cause test failures. The errors and failed tests primarily stem from incorrect assertions and possibly improper handling of dictionary operations in tests, leading to unreliable outcomes and disruptions in development and CI/CD processes.\n\n### Commit Summary\n\nA hypothetical commit to resolve these issues might include the following changes:\n\n```diff\ndiff --git a/piskvorky_sqlitedict/tests/test_temp_db.py b/piskvorky_sqlitedict/tests/test_temp_db.py\nindex abcdefg..hijklmn 100644\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -72,8 +72,9 @@ class TempSqliteDictTest(unittest.TestCase):\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n-        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        # Ensure key sorting separately\n+        self.assertEqual(sorted(self.d.keys()), ['p', 'q', 'r', 'v'])\n \n     def test_handling_errors(self):\n         ''' test_handling_errors\n\ndiff --git a/piskvorky_sqlitedict/tests/test_core.py b/piskvorky_sqlitedict/tests/test_core.py\nindex 1234567..890abcd 100644\n--- a/piskvorky_sqlitedict/tests/test_core.py\n+++ b/piskvorky_sqlitedict/tests/test_core.py\n@@ -251,11 +251,15 @@ class SqliteDictTerminateFailTest(unittest.TestCase):\n \n class NamedSqliteDictCreateOrReuseTest(unittest.TestCase):\n     \n     def test_update_records(self):\n         self.d = SqliteDict()\n         self.d.update([('v', 'w')], p='x', q='y', r='z')\n         self.assertEqual(len(self.d), 4)\n         self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n         self.d.close()\n+\n+    def setUp(self):\n+        self.fname = tempfile.mktemp(suffix='.sqlite')\n+        self.db = SqliteDict(filename=self.fname)\n+\n\n ```\n\n### Explanation of the Fix\n\n1. **Correcting Assertions for Dictionary Items**: \n    - The failing tests in `test_temp_db.py` were using `sorted(self.d)` which sorts keys, not key-value pairs. The fix changes this to `sorted(self.d.items())`, which correctly captures the sorted order of key-value tuples.\n    - Another assertion incorrectly checked the sorted dictionary keys against a tuple list of keys and values simultaneously. The fix separates this into two checks: one for sorted key-value pairs and another just for sorted keys. This provides a clearer and accurate reflection of the dictionary's state.\n\n2. **Enhancing Error Handling and Setup**:\n    - In `test_core.py`, ensuring proper setup with `self.fname` and `self.db` initializes the SQLite dictionary correctly, minimizing issues with creating or reopening the database files.\n\n3. **Addressing Inconsistent Record Management**:\n    - The problematic `test_manage_one_record` and `test_manage_few_records` functions have situations where assertions failed due to incorrect expectations about the dictionary's behavior. Adjusting these to reflect the actual behavior of the `SqliteDict` (particularly with string-to-integer transitions and dictionary item checks) ensures accurate test outcomes.\n\n4. **Ensuring Comprehensive Test Coverage**: \n    - Additional adjustments in the test setup phases to ensure all necessary conditions are met before each test case runs. This change helps avoid scenarios where the database file cannot be opened or records are mismanaged due to inadequate initialization.\n\nBy aligning the assertions with the correct expectations from the `SqliteDict` implementation, these modifications ensure that tests accurately verify the dictionary's state and behavior. Consequently, the tests will now pass consistently, providing reliability in development and CI/CD processes. This commit addresses erroneous assertions and ensures redundant checks are removed, ultimately improving the robustness of the unit tests."
    },
    "issue_ground_truth": {
      "title": "Inconsistent Test Behavior and Assertion Error in SqliteDict Tests",
      "description": "### Issue Description\nCertain tests in the `piskvorky_sqlitedict` library are currently failing due to inconsistencies in values and test assertions. Specifically, when managing dictionary records, the values 'abc' and 100 are causing assertion errors. Furthermore, the tests for checking the integrity of dictionary items and their sorted order are not functioning as intended.\n\n### Impact\nThe faulty tests lead to unreliable test outcomes, which can mask actual issues in the `SqliteDict` implementation. This undermines developer confidence and affects CI/CD pipelines, causing unnecessary delays and complications.\n\n### Steps to Reproduce\n1. Run the existing tests in `piskvorky_sqlitedict/tests/test_temp_db.py`.\n2. Observe failures in tests related to managing individual records and sorting of dictionary items.\n3. Notice the incorrect assertion related to checking values in `piskvorky_sqlitedict/tests/test_core.py`.\n\n### Expected Behavior\nTests should consistently pass without assertion errors, reflecting the actual state and contents of `SqliteDict` accurately.\n\n### Actual Behavior\n- Assertion Error when changing value from 'abc' to 100.\n- Sorting and value checking tests fail due to incorrect assertions.\n- Redundant check for non-existent 'value' in `next_db.values()` causes test failures.\n\n### Possible Solutions\n- Ensuring values are consistent and accurately reflected in tests.\n- Correcting assertions to align with the expected behavior of `SqliteDict`.\n- Removing redundant checks in `piskvorky_sqlitedict/tests/test_core.py` to prevent false negatives during test runs.\n\n### Additional Information\nThis issue aims to improve the reliability and consistency of unit tests, providing a robust foundation for further development and maintenance of the `SqliteDict` library.",
      "explanation": "### Summary of the Issue\n\nThe issue at hand involves failing tests in the `piskvorky_sqlitedict` library, specifically concerning the management of dictionary records and the integrity checks of dictionary items. The failing tests were raising assertion errors when the dictionary values changed from strings to integers. Additionally, tests that checked the order and consistency of dictionary items were not functioning as intended, leading to unreliable test outcomes. These faulty tests erode developer confidence and disrupt CI/CD pipelines, resulting in delays and complications in the development process.\n\n### Detailed Commit Analysis\n\nThe commit provided addresses the aforementioned issues in multiple parts of the test suite. Here's a summary of the key aspects covered by the commit:\n\n1. **Changing Values in Tests (`test_temp_db.py`)**:\n    - The tests were modified to handle string values consistently instead of changing a dictionary value from a string (`'abc'`) to an integer (`100`). This change eliminates the assertion error caused by the type mismatch:\n      - Instead of setting a value to `100`, it was changed to another string (`'lmno'`).\n\n2. **Sorted Dictionary Assertion (`test_temp_db.py`)**:\n   - Modified the assertions to properly compare the sorted representation of `d.items()` and the list of keys to guarantee accurate sorting and comparison.\n\n3. **Redundant Check Removal (`test_core.py`)**:\n   - Removed a redundant assertion that checked for a non-existent value `'value'` in the dictionary’s values, which was causing test failures. This check was logically incorrect and unnecessary.\n\n### Explanation of How the Commit Solves the Issue\n\n**Consistent Value Types:**\n- One of the primary causes of the issue was the inconsistency in value types during dictionary operations, wherein the test altered a dictionary entry from a string to an integer. Since dictionaries expect consistent key-value types for meaningful operations, this abrupt change was generating assertion errors. By ensuring that values remain consistent as strings within the test, it removes the type mismatch and resultant errors. This enhances the reliability of the `SqliteDict`'s behavior under test conditions.\n\n**Proper Sorting Assertion:**\n- Another significant part of the problem was the improper assertion for sorted dictionary items. The original comparison did not account for dictionary item pairs. By refactoring the assertions to compare sorted items and keys separately, the commit ensures the validations correctly reflect the expected order and integrity of dictionary entries. This change guarantees that the tests validate the order of dictionary items accurately.\n\n**Removing Redundant Checks:**\n- The redundant check for a non-existent `'value'` in `next_db.values()` was unnecessary and logically flawed, leading to false test failures. By removing this check, the test assertions are now cleaner and focus on relevant and valid conditions, reducing false negatives and improving overall test accuracy.\n\n### Solution Recap\n\nTo summarize, the commit resolves the issue by:\n\n1. **Maintaining Consistent Value Types:** Ensuring the dictionary values remain as consistent types (in this case, strings) throughout operations within the tests.\n2. **Correct Assertions for Sorting:** Properly validating the sorted state of dictionary entries by checking sorted items and keys, ensuring accurate tests for dictionary content and order.\n3. **Eliminating Redundant Checks:** Removing unnecessary and logically flawed assertions that were causing false test failures.\n\nThese changes together address the root causes of the test failures, resulting in more stable and reliable test outcomes, fostering better confidence in the `SqliteDict` library's functionality and improving the efficiency of CI/CD pipelines."
    },
    "location_origin": [
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": {
          "69": "test_update_records"
        },
        "content_all": {
          "73": "        self.assertEqual(len(self.d), 4)\n",
          "74": "        # As far as I know dicts does not need to return\n",
          "75": "        # the elements in a specified order (sort() is required )\n",
          "76": "        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n",
          "77": "        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n",
          "78": " \n",
          "79": "    def test_handling_errors(self):\n"
        },
        "content_change": {
          "76": "        self.assertEqual(sorted(self.d.keys()), sorted(['q', 'p', 'r', 'v']))\n",
          "77": "        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n"
        }
      }
    ],
    "location_message": [
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": {
          "69": "test_update_records"
        },
        "content_all": {
          "73": "        self.assertEqual(len(self.d), 4)\n",
          "74": "        # As far as I know dicts does not need to return\n",
          "75": "        # the elements in a specified order (sort() is required )\n",
          "76": "        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n",
          "77": "        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n",
          "78": " \n"
        },
        "content_change": {
          "76": "        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n"
        }
      }
    ],
    "location_ground": [
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": {
          "69": "test_update_records"
        },
        "content_all": {
          "68": "",
          "69": "    def test_update_records(self):",
          "70": "        ''' test_update_records",
          "71": "        '''",
          "72": "        self.d.update([('v', 'w')], p='x', q='y', r='z')",
          "73": "        self.assertEqual(len(self.d), 4)",
          "74": "        # As far as I know dicts does not need to return",
          "75": "        # the elements in a specified order (sort() is required )",
          "76": "        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))",
          "77": "        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))",
          "78": ""
        },
        "content_change": {
          "76": "        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))",
          "77": "        # Ensure key sorting separately",
          "78": "        self.assertEqual(sorted(self.d.keys()), ['p', 'q', 'r', 'v'])"
        }
      },
      {
        "file": "piskvorky_sqlitedict/tests/test_core.py",
        "function": {
          "251": "test_update_records"
        },
        "content_all": {
          "250": "",
          "251": "    def test_update_records(self):",
          "252": "        self.d = SqliteDict()",
          "253": "        self.d.update([('v', 'w')], p='x', q='y', r='z')",
          "254": "        self.assertEqual(len(self.d), 4)",
          "255": "        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))",
          "256": "        self.d.close()",
          "257": "",
          "258": "    def setUp(self):",
          "259": "        self.fname = tempfile.mktemp(suffix='.sqlite')",
          "260": "        self.db = SqliteDict(filename=self.fname)",
          "261": ""
        },
        "content_change": {
          "258": "    def setUp(self):",
          "259": "        self.fname = tempfile.mktemp(suffix='.sqlite')",
          "260": "        self.db = SqliteDict(filename=self.fname)"
        }
      },
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": {
          "44": "test_manage_one_record"
        },
        "content_all": {
          "43": "",
          "44": "    def test_manage_one_record(self):",
          "45": "        ''' test_manage_one_record",
          "46": "        '''",
          "47": "        self.d['abc'] = 'rsvp' * 100",
          "48": "        self.assertEqual(self.d['abc'], 'rsvp' * 100)",
          "49": "        self.d['abc'] = 100",
          "50": "        self.assertEqual(self.d['abc'], 100)",
          "51": "        self.assertEqual(len(self.d), 1)",
          "52": "        del self.d['abc']",
          "53": "        self.assertEqual(len(self.d), 0)",
          "54": "        self.assertTrue(not self.d)",
          "55": ""
        },
        "content_change": {
          "49": "        self.d['abc'] = 100",
          "50": "        self.assertEqual(self.d['abc'], 100)"
        }
      }
    ],
    "location_ground_exp": [
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": {
          "44": "test_manage_one_record"
        },
        "content_all": {
          "46": "        ''' test_manage_one_record",
          "47": "        '''",
          "48": "        self.d['abc'] = 'rsvp' * 100",
          "49": "        self.assertEqual(self.d['abc'], 'rsvp' * 100)",
          "50": "        self.d['abc'] = 100",
          "51": "        self.assertEqual(self.d['abc'], 100)",
          "52": "        self.assertEqual(len(self.d), 1)"
        },
        "content_change": {
          "50": "        self.d['abc'] = 'lmno'"
        }
      },
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": {
          "56": "test_manage_few_records"
        },
        "content_all": {
          "62": "        if major_version == 2:",
          "63": "            self.assertEqual(list(self.d.iteritems()), [('abc', 'lmno'), ('xyz', 'pdq')])",
          "64": "        self.assertEqual(list(self.d.items()), [('abc', 'lmno'), ('xyz', 'pdq')])",
          "65": "        self.assertEqual(list(self.d.values()), ['lmno', 'pdq'])",
          "66": "        self.assertEqual(list(self.d.keys()), ['abc', 'xyz'])",
          "67": "        self.assertEqual(list(self.d), ['abc', 'xyz'])"
        },
        "content_change": {
          "64": "        self.assertEqual(sorted(self.d.items()), [('abc', 'lmno'), ('xyz', 'pdq')])",
          "65": "        self.assertEqual(sorted(self.d.values()), ['lmno', 'pdq'])",
          "66": "        self.assertEqual(sorted(self.d.keys()), ['abc', 'xyz'])"
        }
      },
      {
        "file": "piskvorky_sqlitedict/tests/test_core.py",
        "function": {
          "15": "SqliteMiscTest"
        },
        "content_all": {
          "15": "class SqliteMiscTest(unittest.TestCase):",
          "16": "",
          "17": "    def test_with_statement(self):",
          "18": "        \"\"\"Verify using sqlitedict as a contextmanager . \"\"\"",
          "19": "        with SqliteDict(..."
        },
        "content_change": {
          "19": "        with SqliteDict('some.db', autocommit=True) as mydict:"
        }
      }
    ],
    "location_ground_truth": [
      {
        "file": "piskvorky_sqlitedict/tests/test_core.py",
        "function": null,
        "content_all": {
          "133": "        self.assertNotIn('value', next_db.values())\n"
        },
        "content_change": {
          "133": "        self.assertNotIn('value', next_db.values())\n"
        }
      },
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": {
          "44": "test_manage_one_record"
        },
        "content_all": {
          "46": "        '''\n",
          "47": "        self.d['abc'] = 'rsvp' * 100\n",
          "48": "        self.assertEqual(self.d['abc'], 'rsvp' * 100)\n",
          "49": "        self.d['abc'] = 100\n",
          "50": "        self.assertEqual(self.d['abc'], 100)\n",
          "51": "        self.assertEqual(len(self.d), 1)\n",
          "52": "        del self.d['abc']\n",
          "53": "        self.assertEqual(len(self.d), 0)\n"
        },
        "content_change": {
          "49": "        self.d['abc'] = 100\n",
          "50": "        self.assertEqual(self.d['abc'], 100)\n"
        }
      },
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": {
          "69": "test_update_records"
        },
        "content_all": {
          "73": "        self.assertEqual(len(self.d), 4)\n",
          "74": "        # As far as I know dicts does not need to return\n",
          "75": "        # the elements in a specified order (sort() is required )\n",
          "76": "        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n"
        },
        "content_change": {
          "76": "        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n"
        }
      },
      {
        "file": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "function": null,
        "content_all": {
          "77": "        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n"
        },
        "content_change": {
          "77": "        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n"
        }
      }
    ],
    "patch_i": "\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -74,7 +74,8 @@\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n         self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n-        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.keys()), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n \n     def test_handling_errors(self):\n         ''' test_handling_errors\n",
    "patch_im": "\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -73,7 +73,7 @@ def test_update_records(self):\n         self.d.update([('v', 'w')], p='x', q='y', r='z')\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n         self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))        \n",
    "patch_il": "\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -73,7 +73,8 @@\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n-        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.keys()), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n",
    "patch_iml": "\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -73,7 +73,7 @@\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n         self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n \n     def test_handling_errors(self):\n",
    "patch_ground": "\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -72,10 +72,10 @@ def test_update_records(self):\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n-        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        # Ensure key sorting separately\n+        self.assertEqual(sorted(self.d.keys()), ['p', 'q', 'r', 'v'])\n \n-    def test_manage_one_record(self):\n+    def test_handle_single_record(self):\n         ''' test_manage_one_record\n         '''\n         self.d['abc'] = 'rsvp' * 100\n@@ -90,6 +90,7 @@ def test_handle_single_record(self):\n \n     def setUp(self):\n         self.d = SqliteDict()\n+        self.fname = tempfile.mktemp(suffix='.sqlite')\n \n \n--- a/piskvorky_sqlitedict/tests/test_core.py\n+++ b/piskvorky_sqlitedict/tests/test_core.py\n@@ -15,8 +15,10 @@ class SqliteMiscTest(unittest.TestCase):\n class NamedSqliteDictCreateOrReuseTest(unittest.TestCase):\n     \n     def test_update_records(self):\n+        self.d = SqliteDict()\n         self.d.update([('v', 'w')], p='x', q='y', r='z')\n         self.assertEqual(len(self.d), 4)\n         self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        self.d.close()\n \n     def setUp(self):\n         self.fname = tempfile.mktemp(suffix='.sqlite')\n",
    "patch_ground_location": "\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -72,8 +72,9 @@ class TempSqliteDictTest(unittest.TestCase):\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n-        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        # Ensure key sorting separately\n+        self.assertEqual(sorted(self.d.keys()), ['p', 'q', 'r', 'v'])\n\n     def test_handling_errors(self):\n         ''' test_handling_errors\n@@ -47,8 +48,7 @@ class TempSqliteDictTest(unittest.TestCase):\n         self.d['abc'] = 'rsvp' * 100\n         self.assertEqual(self.d['abc'], 'rsvp' * 100)\n         self.d['abc'] = 100\n-        self.assertEqual(self.d['abc'], 100)\n-        self.assertEqual(len(self.d), 1)\n+        self.assertEqual(self.d['abc'], 100) # Removed line 1 as it is redundant\n\n         del self.d['abc']\n         self.assertEqual(len(self.d), 0)\n         self.assertTrue(not self.d)\n--- a/piskvorky_sqlitedict/tests/test_core.py\n+++ b/piskvorky_sqlitedict/tests/test_core.py\n@@ -251,6 +251,10 @@ class SqliteDictTerminateFailTest(unittest.TestCase):\n\n class NamedSqliteDictCreateOrReuseTest(unittest.TestCase):\n     \n+    def setUp(self):\n+        self.fname = tempfile.mktemp(suffix='.sqlite')\n+        self.db = SqliteDict(filename=self.fname)\n+\n     def test_update_records(self):\n         self.d = SqliteDict()\n         self.d.update([('v', 'w')], p='x', q='y', r='z')\n",
    "patch_ground_exp": "\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -48,7 +48,7 @@\n         self.d['abc'] = 'rsvp' * 100\n         self.assertEqual(self.d['abc'], 'rsvp' * 100)\n         self.d['abc'] = 100\n-        self.assertEqual(self.d['abc'], 100)\n+        self.assertEqual(self.d['abc'], 'lmno')\n         self.assertEqual(len(self.d), 1)\n         del self.d['abc']\n         self.assertEqual(len(self.d), 0)\n@@ -64,7 +64,9 @@\n         if major_version == 2:\n             self.assertEqual(list(self.d.iteritems()), [('abc', 'lmno'), ('xyz', 'pdq')])\n         self.assertEqual(list(self.d.items()), [('abc', 'lmno'), ('xyz', 'pdq')])\n-        self.assertEqual(list(self.d.values()), ['lmno', 'pdq'])\n-        self.assertEqual(list(self.d.keys()), ['abc', 'xyz'])\n+        self.assertEqual(sorted(self.d.items()), [('abc', 'lmno'), ('xyz', 'pdq')])\n+        self.assertEqual(sorted(self.d.values()), ['lmno', 'pdq'])\n+        self.assertEqual(sorted(self.d.keys()), ['abc', 'xyz'])\n         self.assertEqual(list(self.d), ['abc', 'xyz'])\n \n \n--- a/piskvorky_sqlitedict/tests/test_core.py\n+++ b/piskvorky_sqlitedict/tests/test_core.py\n@@ -19,7 +19,7 @@\n         \"\"\"Verify using sqlitedict as a contextmanager . \"\"\"\n         with SqliteDict('some.db', autocommit=True) as mydict:\n             mydict['some_key'] = 'some_value'\n-        self.assertIn('value', mydict.values())\n+        self.assertIn('some_value', mydict.values())\n \n     def test_open_close(self):\n         \"\"\"Test explicit open/close of the database.\"\"\"\n",
    "patch_ground_all": "\n--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -46,8 +46,8 @@ def test_manage_one_record(self):\n         '''\n         self.d['abc'] = 'rsvp' * 100\n         self.assertEqual(self.d['abc'], 'rsvp' * 100)\n-        self.d['abc'] = 100\n-        self.assertEqual(self.d['abc'], 100)\n+        self.d['abc'] = 'lmno'\n+        self.assertEqual(self.d['abc'], 'lmno')\n         self.assertEqual(len(self.d), 1)\n         del self.d['abc']\n         self.assertEqual(len(self.d), 0)\n@@ -76,7 +76,7 @@ def test_update_records(self):\n         self.d.update([('v', 'w')], p='x', q='y', r='z')\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n-        # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        # the elements in a specified order (sort() is required)\n         self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n         self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n \n--- a/piskvorky_sqlitedict/tests/test_core.py\n+++ b/piskvorky_sqlitedict/tests/test_core.py\n@@ -133,7 +133,6 @@ def test_with_statement(self):\n \n         with SqliteDict(temp_file, autocommit=True) as next_db:\n             self.assertEqual(next_db['key'], value)\n-            self.assertNotIn('value', next_db.values())\n             self.assertEqual(list(next_db.keys()), ['key'])\n             self.assertEqual(list(next_db.values()), [value])\n             self.assertEqual(list(next_db.items()), [('key', value)])\n",
    "patch_ground_truth": "--- a/piskvorky_sqlitedict/tests/test_temp_db.py\n+++ b/piskvorky_sqlitedict/tests/test_temp_db.py\n@@ -46,8 +46,8 @@\n         '''\n         self.d['abc'] = 'rsvp' * 100\n         self.assertEqual(self.d['abc'], 'rsvp' * 100)\n-        self.d['abc'] = 100\n-        self.assertEqual(self.d['abc'], 100)\n+        self.d['abc'] = 'lmno'\n+        self.assertEqual(self.d['abc'], 'lmno')\n         self.assertEqual(len(self.d), 1)\n         del self.d['abc']\n         self.assertEqual(len(self.d), 0)\n@@ -73,8 +73,8 @@\n         self.assertEqual(len(self.d), 4)\n         # As far as I know dicts does not need to return\n         # the elements in a specified order (sort() is required )\n-        self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n-        self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n+        self.assertEqual(sorted(self.d.items()), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n+        self.assertEqual(sorted(list(self.d)), sorted(['q', 'p', 'r', 'v']))\n \n     def test_handling_errors(self):\n         ''' test_handling_errors\n--- a/piskvorky_sqlitedict/tests/test_core.py\n+++ b/piskvorky_sqlitedict/tests/test_core.py\n@@ -130,7 +130,6 @@\n         # verify,\n         next_db = SqliteDict(filename=fname, tablename='sometable', flag='n')\n         self.assertNotIn('key', next_db.keys())\n-        self.assertNotIn('value', next_db.values())\n \n     def test_unrecognized_flag(self):\n \n",
    "message": "======================================================================\nERROR: test_terminate_cannot_delete (test_core.SqliteDictTerminateFailTest)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_core.py\", line 254, in setUp\n    self.db = SqliteDict(filename=self.fname)\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 229, in __init__\n    self.conn.execute(MAKE_TABLE)\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 616, in execute\n    self.check_raise_error()\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 606, in check_raise_error\n    reraise(e_type, e_value, e_tb)\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 46, in reraise\n    raise value.with_traceback(tb)\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/sqlitedict.py\", line 474, in _connect\n    conn = sqlite3.connect(self.filename, check_same_thread=False)\nsqlite3.OperationalError: unable to open database file\n\n======================================================================\nFAIL: test_update_records (test_core.NamedSqliteDictCreateOrReuseTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_temp_db.TempSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.CreateNewSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.InMemorySqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.NamedSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.SqliteDictAutocommitTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_named_db.StartsWithEmptySqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_temp_db.TempSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n======================================================================\nFAIL: test_update_records (test_temp_db.TempSqliteDictTest)\ntest_update_records\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/home/user/Documents/repoben/buggycode/piskvorky_sqlitedict/tests/test_temp_db.py\", line 76, in test_update_records\n    self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\nAssertionError: Lists differ: ['p', 'q', 'r', 'v'] != [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\nFirst differing element 0:\n'p'\n('p', 'x')\n\n- ['p', 'q', 'r', 'v']\n+ [('p', 'x'), ('q', 'y'), ('r', 'z'), ('v', 'w')]\n\n----------------------------------------------------------------------\nRan 88 tests in 1.115s\n\nFAILED (failures=9, errors=1)",
    "CodeBase": [
      {
        "path": "piskvorky_sqlitedict/tests/test_temp_db.py",
        "content": "1 #!/usr/bin/env python\n2 # -*- coding: utf-8 -*-\n3 #\n4 # This code is distributed under the terms and conditions\n5 # from the Apache License, Version 2.0\n6 import unittest\n7 import sqlitedict\n8 \n9 from sys import version_info\n10 major_version = version_info[0]\n11 \n12 \n13 class TempSqliteDictTest(unittest.TestCase):\n14 \n15     def setUp(self):\n16         self.d = sqlitedict.SqliteDict()\n17 \n18     def tearDown(self):\n19         self.d.close()\n20 \n21     def test_create_sqlitedict(self):\n22         ''' test_create_sqlitedict\n23         '''\n24         self.assertIsInstance(self.d, sqlitedict.SqliteDict)\n25         self.assertEqual(dict(self.d), {})\n26         self.assertEqual(list(self.d), [])\n27         self.assertEqual(len(self.d), 0)\n28 \n29     def test_assign_values(self):\n30         ''' test_assign_values\n31         '''\n32         self.d['abc'] = 'edf'\n33         self.assertEqual(self.d['abc'], 'edf')\n34         self.assertEqual(len(self.d), 1)\n35 \n36     def test_clear_data(self):\n37         ''' test_clear_data\n38         '''\n39         self.d.update(a=1, b=2, c=3)\n40         self.assertEqual(len(self.d), 3)\n41         self.d.clear()\n42         self.assertEqual(len(self.d), 0)\n43 \n44     def test_manage_one_record(self):\n45         ''' test_manage_one_record\n46         '''\n47         self.d['abc'] = 'rsvp' * 100\n48         self.assertEqual(self.d['abc'], 'rsvp' * 100)\n49         self.d['abc'] = 100\n50         self.assertEqual(self.d['abc'], 100)\n51         self.assertEqual(len(self.d), 1)\n52         del self.d['abc']\n53         self.assertEqual(len(self.d), 0)\n54         self.assertTrue(not self.d)\n55 \n56     def test_manage_few_records(self):\n57         ''' test_manage_few_records\n58         '''\n59         self.d['abc'] = 'lmno'\n60         self.d['xyz'] = 'pdq'\n61         self.assertEqual(len(self.d), 2)\n62         if major_version == 2:\n63             self.assertEqual(list(self.d.iteritems()), [('abc', 'lmno'), ('xyz', 'pdq')])\n64         self.assertEqual(list(self.d.items()), [('abc', 'lmno'), ('xyz', 'pdq')])\n65         self.assertEqual(list(self.d.values()), ['lmno', 'pdq'])\n66         self.assertEqual(list(self.d.keys()), ['abc', 'xyz'])\n67         self.assertEqual(list(self.d), ['abc', 'xyz'])\n68 \n69     def test_update_records(self):\n70         ''' test_update_records\n71         '''\n72         self.d.update([('v', 'w')], p='x', q='y', r='z')\n73         self.assertEqual(len(self.d), 4)\n74         # As far as I know dicts does not need to return\n75         # the elements in a specified order (sort() is required )\n76         self.assertEqual(sorted(self.d), sorted([('q', 'y'), ('p', 'x'), ('r', 'z'), ('v', 'w')]))\n77         self.assertEqual(sorted(self.d), sorted(['q', 'p', 'r', 'v']))\n78 \n79     def test_handling_errors(self):\n80         ''' test_handling_errors\n81         '''\n82         def get_value(d, k):\n83             return d[k]\n84 \n85         def remove_nonexists(d, k):\n86             del d[k]\n87 \n88         with self.assertRaises(KeyError):\n89             remove_nonexists(self.d, 'abc')\n90         with self.assertRaises(KeyError):\n91             get_value(self.d, 'abc')"
      },
      {
        "path": "piskvorky_sqlitedict/sqlitedict.py",
        "content": "1 #!/usr/bin/env python\n2 # -*- coding: utf-8 -*-\n3 #\n4 # This code is distributed under the terms and conditions\n5 # from the Apache License, Version 2.0\n6 #\n7 # http://opensource.org/licenses/apache2.0.php\n8 #\n9 # This code was inspired by:\n10 #  * http://code.activestate.com/recipes/576638-draft-for-an-sqlite3-based-dbm/\n11 #  * http://code.activestate.com/recipes/526618/\n12 \n13 \"\"\"\n14 A lightweight wrapper around Python's sqlite3 database, with a dict-like interface\n15 and multi-thread access support::\n16 \n17 >>> mydict = SqliteDict('some.db', autocommit=True) # the mapping will be persisted to file `some.db`\n18 >>> mydict['some_key'](...truncated)"
      },
      {
        "path": "piskvorky_sqlitedict/tests/test_core.py",
        "content": "1 # std imports\n2 import json\n3 import unittest\n4 import tempfile\n5 import os\n6 from unittest.mock import patch\n7 \n8 # local\n9 import sqlitedict\n10 from sqlitedict import SqliteDict\n11 from test_temp_db import TempSqliteDictTest\n12 from accessories import norm_file\n13 \n14 \n15 class SqliteMiscTest(unittest.TestCase):\n16 \n17     def test_with_statement(self):\n18         \"\"\"Verify using sqlitedict as a contextmanager . \"\"\"\n19         with Sqlite(...truncated)"
      },
      {
        "path": "piskvorky_sqlitedict/tests/test_autocommit.py",
        "content": "1 import os\n2 import sys\n3 \n4 import sqlitedict\n5 \n6 \n7 def test():\n8     \"Verify autocommit just before program exits.\"\n9     assert os.system('env PYTHONPATH=. %s tests/autocommit.py' % sys.executable) == 0\n10     # The above script relies on the autocommit feature working correctly.\n11     # Now, let's check if it actually worked.\n12     d = sqlitedict.SqliteDict('tests/db/autocommit.sqlite')\n13     for i in range(1000):\n14         assert d[i] == i, \"actual: %s expected: %s\" % (d[i], i)"
      },
      {
        "path": "piskvorky_sqlitedict/tests/test_named_db.py",
        "content": "1 import sqlitedict\n2 from test_temp_db import TempSqliteDictTest\n3 from accessories import norm_file\n4 \n5 \n6 class (...truncated)"
      },
      {
        "path": "piskvorky_sqlitedict/setup.py",
        "content": "1 #!/usr/bin/env python\n2 # -*- coding: utf-8 -*-\n3 #\n4 # Th(...truncated)"
      }
    ],
    "CommitSHA": "96e81621fd6ab094efdd86e70fd57efe9d40ca12"
  },
  "Score": {
    "Difficulty": "Medium",
    "issue_origin": {
      "Title": 7,
      "Description": 6,
      "Reproducibility": 5,
      "Relevance": 8,
      "Explanation": 7,
      "Overall": 7
    },
    "issue_message": {
      "Title": 5,
      "Description": 4,
      "Reproducibility": 3,
      "Relevance": 7,
      "Explanation": 6,
      "Overall": 5
    },
    "issue_ground": {
      "Title": 8,
      "Description": 8,
      "Reproducibility": 7,
      "Relevance": 8,
      "Explanation": 7,
      "Overall": 8
    },
    "issue_ground_truth": {
      "title": "Inconsistent Test Behavior and Assertion Error in SqliteDict Tests",
      "description": "### Issue Description\nCertain tests in the `piskvorky_sqlitedict` library are currently failing due to inconsistencies in values and test assertions. Specifically, when managing dictionary records, the values 'abc' and 100 are causing assertion errors. Furthermore, the tests for checking the integrity of dictionary items and their sorted order are not functioning as intended.\n\n### Impact\nThe faulty tests lead to unreliable test outcomes, which can mask actual issues in the `SqliteDict` implementation. This undermines developer confidence and affects CI/CD pipelines, causing unnecessary delays and complications.\n\n### Steps to Reproduce\n1. Run the existing tests in `piskvorky_sqlitedict/tests/test_temp_db.py`.\n2. Observe failures in tests related to managing individual records and sorting of dictionary items.\n3. Notice the incorrect assertion related to checking values in `piskvorky_sqlitedict/tests/test_core.py`.\n\n### Expected Behavior\nTests should consistently pass without assertion errors, reflecting the actual state and contents of `SqliteDict` accurately.\n\n### Actual Behavior\n- Assertion Error when changing value from 'abc' to 100.\n- Sorting and value checking tests fail due to incorrect assertions.\n- Redundant check for non-existent 'value' in `next_db.values()` causes test failures.\n\n### Possible Solutions\n- Ensuring values are consistent and accurately reflected in tests.\n- Correcting assertions to align with the expected behavior of `SqliteDict`.\n- Removing redundant checks in `piskvorky_sqlitedict/tests/test_core.py` to prevent false negatives during test runs.\n\n### Additional Information\nThis issue aims to improve the reliability and consistency of unit tests, providing a robust foundation for further development and maintenance of the `SqliteDict` library.",
      "explanation": "### Summary of the Issue\n\nThe issue at hand involves failing tests in the `piskvorky_sqlitedict` library, specifically concerning the management of dictionary records and the integrity checks of dictionary items. The failing tests were raising assertion errors when the dictionary values changed from strings to integers. Additionally, tests that checked the order and consistency of dictionary items were not functioning as intended, leading to unreliable test outcomes. These faulty tests erode developer confidence and disrupt CI/CD pipelines, resulting in delays and complications in the development process.\n\n### Detailed Commit Analysis\n\nThe commit provided addresses the aforementioned issues in multiple parts of the test suite. Here's a summary of the key aspects covered by the commit:\n\n1. **Changing Values in Tests (`test_temp_db.py`)**:\n    - The tests were modified to handle string values consistently instead of changing a dictionary value from a string (`'abc'`) to an integer (`100`). This change eliminates the assertion error caused by the type mismatch:\n      - Instead of setting a value to `100`, it was changed to another string (`'lmno'`).\n\n2. **Sorted Dictionary Assertion (`test_temp_db.py`)**:\n   - Modified the assertions to properly compare the sorted representation of `d.items()` and the list of keys to guarantee accurate sorting and comparison.\n\n3. **Redundant Check Removal (`test_core.py`)**:\n   - Removed a redundant assertion that checked for a non-existent value `'value'` in the dictionary’s values, which was causing test failures. This check was logically incorrect and unnecessary.\n\n### Explanation of How the Commit Solves the Issue\n\n**Consistent Value Types:**\n- One of the primary causes of the issue was the inconsistency in value types during dictionary operations, wherein the test altered a dictionary entry from a string to an integer. Since dictionaries expect consistent key-value types for meaningful operations, this abrupt change was generating assertion errors. By ensuring that values remain consistent as strings within the test, it removes the type mismatch and resultant errors. This enhances the reliability of the `SqliteDict`'s behavior under test conditions.\n\n**Proper Sorting Assertion:**\n- Another significant part of the problem was the improper assertion for sorted dictionary items. The original comparison did not account for dictionary item pairs. By refactoring the assertions to compare sorted items and keys separately, the commit ensures the validations correctly reflect the expected order and integrity of dictionary entries. This change guarantees that the tests validate the order of dictionary items accurately.\n\n**Removing Redundant Checks:**\n- The redundant check for a non-existent `'value'` in `next_db.values()` was unnecessary and logically flawed, leading to false test failures. By removing this check, the test assertions are now cleaner and focus on relevant and valid conditions, reducing false negatives and improving overall test accuracy.\n\n### Solution Recap\n\nTo summarize, the commit resolves the issue by:\n\n1. **Maintaining Consistent Value Types:** Ensuring the dictionary values remain as consistent types (in this case, strings) throughout operations within the tests.\n2. **Correct Assertions for Sorting:** Properly validating the sorted state of dictionary entries by checking sorted items and keys, ensuring accurate tests for dictionary content and order.\n3. **Eliminating Redundant Checks:** Removing unnecessary and logically flawed assertions that were causing false test failures.\n\nThese changes together address the root causes of the test failures, resulting in more stable and reliable test outcomes, fostering better confidence in the `SqliteDict` library's functionality and improving the efficiency of CI/CD pipelines."
    }
  }
}