- 01 Apr, 2005 4 commits
-
-
Tim Peters authored
-
Tim Peters authored
-
Tim Peters authored
-
Tim Peters authored
3.3 should have bumped the ZEO protocol number (new methods were added for MVCC support), but didn't. Untangling this is a mess.
-
- 30 Mar, 2005 1 commit
-
-
Tim Peters authored
Believe it or not, ZopeUndo is ZEO code, not Zope code. r29726 | slinkp | 2005-03-30 02:11:22 -0500 (Wed, 30 Mar 2005) | 3 lines Changed paths: M /Zope/trunk/lib/python/ZopeUndo/Prefix.py M /Zope/trunk/lib/python/ZopeUndo/tests/testPrefix.py Merged slinkp_1726_zopeundo: avoid showing undo transactions in the wrong folder.
-
- 28 Mar, 2005 3 commits
-
-
Tim Peters authored
checkTimeoutProvokingConflicts: try to fix rare failures. This always slept for 3 seconds, waiting for the storage to disconnect. This loses on two counts: 1. Since the timeout is set to 1 second, it typically sleeps longer than necessary. 2. Since there's no predicting thread and process scheduling, 3 seconds isn't always long enough, and rare failures have been reported against this test. Instead we do a polling loop now. This typically succeeds in a little more than a second, speeding the normal case. The loop will continue trying for up to a minute if not.
-
Tim Peters authored
-
Tim Peters authored
-
- 24 Mar, 2005 1 commit
-
-
Tim Peters authored
Stop silent data loss in some BTree cases where a transaction adds a new key to a bucket while a concurrent transaction deletes all keys from the same bucket. Still needs porting to ZODB trunk and to 3.2 line.
-
- 20 Mar, 2005 1 commit
-
-
Tim Peters authored
The ZODB4 BTrees excludemin/excludemax arguments got implemented in 3.3, but the corresponding changes to the BTrees interface file got dropped on the floor.
-
- 17 Mar, 2005 1 commit
-
-
Tim Peters authored
r29511 | gotcha | 2005-03-16 11:01:21 -0500 (Wed, 16 Mar 2005) | 1 line Changed paths: M /Zope/trunk/utilities/ZODBTools/zodbload.py port features from 2.7
-
- 14 Mar, 2005 1 commit
-
-
Tim Peters authored
Allow those old (ZODB 3.2) dotted paths to work again. Fallout: testPersistentMapping.py hasn't actually run anything for a long time, due to a mysterious "return None" at the start of its test_suite() function. Removed that. Then its checkNewPicklesAreSafe test failed. Spent 15 minutes on that, and gave up -- I'm still not even sure what it's _trying_ to test. Changed it to a TODO.
-
- 12 Mar, 2005 1 commit
-
-
Tim Peters authored
ZODB is an XXX-free zone now.
-
- 11 Mar, 2005 2 commits
-
-
Tim Peters authored
Convert some XXXs. More to come.
-
Tim Peters authored
Convert some XXXs. More to come.
-
- 07 Mar, 2005 1 commit
-
-
Tim Peters authored
-
- 01 Mar, 2005 1 commit
-
-
Tim Peters authored
native platorm address size.
-
- 28 Feb, 2005 1 commit
-
-
Tim Peters authored
Change FileStorage .restore() and .store() to update max oid in use. This is the last of the checkins to fix critical bugs involving rare cases where a FileStorage could end up reusing old oids for new objects.
-
- 25 Feb, 2005 1 commit
-
-
Tim Peters authored
Stop believing the maximum oid cached in a FileStorage's .index file. This is a critical bugfix, although the problems it addresses are (a) rare; and, (b) not entirely fixed yet (more checkins to come). The true max oid is found efficiently now by exploiting the recently-added fsIndex.maxKey() method (which was, of course, added for this purpose). Also fix that the .index file could get updated on disk when the FileStorage was opened in read-only mode. The code was trying to prevent this, but missed the most obvious rewrite path. Incidentally improved many obsolete and/or incorrect comments.
-
- 24 Feb, 2005 2 commits
-
-
Tim Peters authored
Give fsIndex an efficient maxKey() implementation. This will (in a later checkin) be used to give FileStorage an "obviously correct" way to determine the largest oid used in an .fs.index file.
-
Tim Peters authored
Note that cPickleCache.c must be recompiled else the new test will fail. Change the exception raised when an attempt is made to add two objects to the cache with the same oid. The former messsage didn't make sense. Add a test to verify that this exception does get raised, and that the message given is the intended one. This is the first of a series of checkins, to fix critical bugs where ZODB can in fact raise this exception in rare, but normal, use cases.
-
- 17 Feb, 2005 1 commit
-
-
Tim Peters authored
The current default is 200MB, and at least testSerialization reads the entire cache file into one giant string. That grossly boosts the process highwater mark when running the tests. Windows reclaims the memory after, but other platforms may not. Cool: testSerialization was one of the slowest tests before, but is 100x faster now.
-
- 10 Feb, 2005 1 commit
-
-
Tim Peters authored
r28991 | jim | 2005-01-31 10:45:46 -0500 (Mon, 31 Jan 2005) | 5 lines ... Renamed the Zope package to Zope2 Import of the Zope package is now deprecated, but will be supported until Zope 2.11.
-
- 09 Feb, 2005 1 commit
-
-
Tim Peters authored
Connection.__init__(): Python 2.4 added a new gimmick to asyncore (a ._map attribute on asyncore.dispatcher instances) that breaks the delicate ZEO startup dance. Repaired that.
-
- 05 Feb, 2005 1 commit
-
-
Tim Peters authored
Fixed several thread and asyncore races in ZEO's connection dance. ZEO/tests/ConnectionTests.py The pollUp() and pollDown() methods were pure busy loops whenever the asyncore socket map was empty, and at least on some flavors of Linux that starved the other thread(s) trying to do real work. This grossly increased the time needed to run tests using these, and sometimes caused bogus "timed out" test failures. ZEO/zrpc/client.py ZEO/zrpc/connection.py Renamed class ManagedConnection to ManagedClientConnection, for clarity. Moved the comment block about protocol negotiation from the guts of ManagedClientConnection to before the Connection base class -- the Connection constructor can't be understood without this context. Added more words about the delicate protocol negotiation dance. Connection class: made this an abstract base clase. Derived classes _must_ implement the handshake() method. There was really nothing in common between server and client wrt what handshake() needs to do, and it was confusing for one of them to use the base class handshake() while the other replaced handshake() completely. Connection.__init__: It isn't safe to register with asyncore's socket map before special-casing for the first (protocol handshake) message is set up. Repaired that. Also removed the pointless "optionalness" of the optional arguments. ManagedClientConnection.__init__: Added machinery to set up correct (thread-safe) message queueing. There was an unrepairable hole before, in the transition between "I'm queueing msgs waiting for the server handshake" and "I'm done queueing messages": it was impossible to know whether any calls to the client's "queue a message" method were in progress (in other threads), so impossible to make the transition safely in all cases. The client had to grow its own message_output() method, with a mutex protecting the transition from thread races. Changed zrpc-conn log messages to include "(S)" for server-side or "(C)" for client-side. This is especially helpful for figuring out logs produced while running the test suite (the server and client log messages end up in the same file then).
-
- 24 Jan, 2005 2 commits
-
-
Tim Peters authored
bugfixes have piled up since this was last done.
-
Tim Peters authored
-
- 12 Jan, 2005 2 commits
-
-
Tim Peters authored
ZODB cache size is an integer (number of objects), not a number of bytes.
-
Tim Peters authored
Merge rev 28470 from Zope3 trunk. Typo repair checked in from a wrong project.
-
- 11 Jan, 2005 2 commits
-
-
Tim Peters authored
-
Tim Peters authored
-
- 07 Jan, 2005 1 commit
-
-
Tim Peters authored
Collector 1503: excessive logging. ClientStorage._wait_sync(): Don't log more than one "waiting for cache verification to finish" message per 5 minutes.
-
- 23 Dec, 2004 1 commit
-
-
Tim Peters authored
ClientCache.invalidate(): - This was written not to expect tid=None, which is what happens during cache verification, although it didn't catch the tid=None case and went on doing really strange things then. Rewrote so that tid=None means "forget everything I think I know about the oid". It was kind-of performing an invalidation wrt the in-memory data structures in this case, but leaving the invalidated data for oid looking as if it were still current on disk. That was accidental, depending on what various other parts of the code thought "None" meant (primarily, an end_tid of None is generally taken here to mean "the data is current"). - Also changed the "and we already have version data for oid" case to a "forget everything I think I know about the oid" case. The comments seemed to say that's what it thought it was doing, but the code actually left non-current revisions sitting around. I really don't want to spend time trying to figure out what versions are supposed to do in all cases here, and nuking everything in this case is an obviously *safe* thing to do. - Added more asserts, because the pre- and post-conditions here are delicate and non-obvious (indeed, that a new assert failed is how I stumbled into the invalidation problem to begin with). FileCache.remove(): Changed to remove the key from self.key2entry. While self.filemap keeps an in-memory map of the entire disk file, there's no need to keep info in key2entry for keys that no longer exist in the disk file. I'm not sure a visible bug followed from this (but not sure one didn't either!), but it at best wasted memory, and violated a documented invariant. ConnectionTests.py: New test checkVerificationInvalidationPersists(). Before the patch, this provokes a persistent ZEO cache into delivering stale object state. Of course the test passes after this patch. stats.py: Added a trace code meaning "invalidation hit, and the object state was discarded". This is what happens now for invalidations produced by verification. Because of MVCC, that's really not needed *except* for the invalidations produced by startup verification (invalidations normally just set a new ending tid on the validity range for what was current data; but validity-range info isn't available from verification invalidations).
-
- 22 Dec, 2004 1 commit
-
-
Tim Peters authored
Also split test checkRollover into two tests, checkDisconnectedCacheWorks (persistent ZEO cache large enough to satisfy all requests) and checkDisconnectedCacheFails (cache too small to satisfy all requests while disconnected).
-
- 21 Dec, 2004 5 commits
-
-
Tim Peters authored
Object.serialize_header(): Stopped stuffing the version string into this notion of "a header". Couldn't see any reason for it, and it was surprising. ClientCache.invalidate(): Added some asserts to clarify intended preconditions. Alas, my guess that it was intended that the passed-in tid always be greater than the current tid turned out to trigger errors. This gets complicated, and hasn't been resolved yet. The problem is that the passed-in tid can be (in fact, always is) None during cache verification. The code here *really* doesn't seem to be expecting that, and the on-disk cache file is clearly left in a wrong state (if we repopulated the cache from the disk file, the object would not look invalidated any more, it would look current). Dumped in a giant stack trace so I don't forget this; sent email to Jeremy asking if he recalls what the real intent was.
-
Tim Peters authored
- Object.fromFile(): renamed `header_only` arg to `skip_data`. Skipping the data is what it does, while there are at least 3 distinct notions of what "a header" means in this module. Object has two notions of "header" all by itself (& I'm still not sure why Object.serialize_header() considers the version string to be part of "the header"). - FileCache.__init__(): log a warning if reuse=True but the given file path doesn't exist. The code ignores `reuse` then (before, and now). Not sure that's the best thing to do.
-
Tim Peters authored
- Moved the logger object to module scope. There's virtually no logging of any kind done here, and I suspect that's partly because the logging object was clumsy to get at. - Figured out what the code actually does when the cache size asked for doesn't match the actual size of a pre-existing cache file. It apparently wanted to ignore the requested size then. It probably shouldn't, but leaving that for later. Still, it left its own idea of the file size out of synch with the actual file size, and that was a bug. For now, logged a warning when this happens, and changed the code to respect the actual file size.
-
Tim Peters authored
ClientCache: Removed the .tid attribute. It was never updated; the contained FileCache instance actually keeps track of the last tid. This had the happy side effect of fixing bugs in testSerialization: it was accessing .tid directly, and so was _always_ comparing None to None. Changing the test to use .getLastTid() instead means it's now testing what it always intended to test. FileCache: Removed some unused private attributes for tracking internal statistics.
-
Tim Peters authored
FileCache: removed the currentsize attribute. It was initialized to 0 but never updated. Some tests referenced it, but since it was always 0 those tests weren't getting any good from it. Don't recall (or never knew) what its intended purpose may have been. FileCache.remove(): Repaired major bug. This mistakenly stored the "this disk block is free now" status byte into the start of the serialized Object record's end_tid field (incorrect seek offset). The in-memory structures were correct then, but got out of synch with the disk file; the latter then still claimed to have info for a "live" object revision, but that revision was actually dead, and the info on disk had a corrupt end_tid value.
-
- 20 Dec, 2004 1 commit
-
-
Tim Peters authored
-