summaryrefslogtreecommitdiff
path: root/src
Commit message (Collapse)AuthorAgeFilesLines
* Bump version as suggested in review.no-pure-python-buildJason Madden2020-01-221-0/+1
| | | | Also add a line of missing whitespace.
* Tweaks for coverage reporting.Jason Madden2020-01-211-2/+2
| | | | And tox. It wasn't properly working to report coverage before.
* Test PURE_PYTHON at runtime.Jason Madden2020-01-219-260/+350
| | | | | | | Turns out that the C extensions build and work fine with PyPy, but don't use them by default. Let them be forced, though. Tests needed some refactoring to account for the various permutations.
* Remove unused test files.Jason Madden2020-01-213-67/+0
|
* key order doesn't mattermauro2019-10-091-1/+1
|
* fix 'dict_keys' object has no attribute 'extend'mauro2019-10-091-3/+5
|
* taggedvalue inheritancemauro2019-10-092-2/+36
|
* Fix coverage.issue126Jason Madden2018-10-231-2/+2
|
* Fix 'verifyObject' for class objects with staticmethods on Python 3.Jason Madden2018-10-232-1/+25
| | | | Fixes #126
* Reorganize the 'declarations' document by functional group.Jason Madden2018-07-192-42/+42
| | | | Add cross references and some formatting fixes.
* Formatting and cross refs for the 'Interface Specification' docJason Madden2018-07-192-26/+27
|
* Formatting and cross refs for IComponents.Jason Madden2018-07-191-114/+102
|
* Formatting for z.i.common.sequences.Jason Madden2018-07-191-22/+27
|
* Cross references and formatting for z.i.common.mappingJason Madden2018-07-191-17/+42
|
* Cross references and formatting for z.i.common.idatetime.Jason Madden2018-07-191-68/+99
|
* Add docstrings with cross-refs to z.i.common.interfacesJason Madden2018-07-191-56/+166
| | | | | | Also bring the ``classImplements`` lines closer to the interface declaration. This helped me be sure that nothing was missed and that all the repetitions of the names matched.
* Synchronize and simplify zope/__init__.pyissue114Jason Madden2018-03-081-7/+1
| | | | | | We *do* have a dependency on setuptools, so the try/except block should be unnecessary. At worst it might hide installation errors. Fixes #114.
* Allow Registering and unregistering instance methods as listeners (#102)‮rekcäH nitraM‮2017-11-282-1/+12
| | | * Fixes #12 - registering instance methods as listeners doesn’t allow to easily unregister them as the registry tries to find the handler with 'is' but it should use '==' to allow the python BoundMethod wrapper (which is a new instance every time instance.$methodname is accessed).
* I removed an unnecessary whitespace.y-fujisaki22017-09-211-1/+1
| | | Thank you for follows. I misread it for carriage return.
* Fix process of reference count during GCy-fujisaki22017-09-191-1/+3
| | | | | | call PyObject_GC_UnTrack() in tp_dealloc() see the following sites for details: * https://bugs.python.org/issue31095 * https://github.com/python/cpython/pull/2974
* Drop __annotations__ in interface declarationsMaxim Avanov2017-09-012-1/+11
|
* Merge pull request #95 from zopefoundation/combined-coverageJason Madden2017-06-1413-62/+68
|\ | | | | Enable combined coverage reports under tox and branch coverage
| * cleanups requested by @tseaver: remove assert from _implements since all its ↵Jason Madden2017-06-142-3/+5
| | | | | | | | callers already do this guard; be more explicit about ClassType in test_odd_declarations
| * Enable combined coverage reports under tox and branch coveragecombined-coverageJason Madden2017-06-1413-61/+65
| | | | | | | | | | | | | | | | Fixes #91 Remove many (or most) now-redundant 'pragma: no cover'. A few minor test changes to get full branch coverage.
* | Fix the cache getting out of sync with _utility_registrations.issue93Jason Madden2017-06-142-13/+69
|/ | | | Fixes #93
* Fix #85 by implementing __reduce__ to omit _v_ attributes.issue85-take2-reduceJason Madden2017-06-142-5/+121
| | | | | | | | | | This is an alternative to #86 and was suggested by @mgedmin in #85. There are tests to be sure this works for subclasses like Pyramid's Registry that extend dict too. This doesn't change the pickle format, we were storing the output of object.__reduce__ previously.
* 100% coverage (#90)Jason Madden2017-06-1214-271/+195
| | | | | | | | | | | | | | | | | | | | | * Get as close to 100% coverage as possible. Without conflicting with #86. This is almost entirely trivial changes: - Make dummy methods that should never be called either raise NotImplementedError or call self.fail() in tests. - Standardize the no-coverage pragma - Add a few pragmas where coverage varies across versions/implementations, mostly for the sake of tox (travis should hit them all). * Convert tox to run the coverage command, like travis. A follow up should have it produce coverage for all python versions/implementations. Fixes #87 * Adjust coverage config for py2 only tests; fix typo; finish replacing self with cls
* Test sanity cleanups (#88)Jason Madden2017-06-0816-216/+102
| | | | | | | | | | | | | | | | | | | * Test sanity cleanups Partially addresses #87 - Remove manual lists of tests in favor of loadTestsFromName. This mostly gets all test runners running the same number of tests. - Remove `additional_tests`, which was just duplicating the discovered tests. No modern test runner seems to need it. - Change the two compatibility skip decorators to actually use unitetest skips, which helps with the reporting. * Per @tseaver, drop most test_suite functions. * Port remaining doctest to unittest. * Make the odd tests work on all supported python versions
* Added some comments to describe the management of _v_utility_registrations_cachesimplify-utility-registrations-cacheJim Fulton2017-05-121-0/+7
|
* Simply the caching of utility-registration data. In addition toJim Fulton2017-05-122-43/+16
| | | | | simplification, avoids spurious test failures when checking for leaks in tests with persistent registries.
* Raise ValueError if non-text name passed to adapter registry methods.75-prevent-non-text-name-errorsTres Seaver2017-05-044-3/+82
| | | | | | Prevents corruption of lookup cache. Alternative to fix proposed in #75.
* Don't redefine METH_KEYWORDSJason Madden2017-01-051-88/+83
| | | | | | Instead, use the intended METH_KEYWORDS | METH_VARARGS spelling. Fixes #71
* Merge pull request #66 from zopefoundation/41-document-adapter-registry-apiTres Seaver2016-12-061-0/+4
|\ | | | | Document API for adapter registry.
| * Document API for adapter registry.Tres Seaver2016-12-061-0/+4
| | | | | | | | Closes: #41.
* | Fix docstring summary line for 'unregisterAdapter'.Tres Seaver2016-12-061-1/+1
|/ | | | | | Closes #23. [ci skip]
* Merge branch 'master' of github.com:zopefoundation/zope.interfaceJean Jordaan2016-12-067-12/+126
|\ | | | | | | | | | | | | Conflicts: CHANGES.rst I think that was the simplest conflict resolution ever :-]
| * Add tests asserting that optimzations are / are not present as expected.Tres Seaver2016-11-153-0/+103
| |
| * Fix C optimizations broken on Py3k.60-fix_c_optimizations-py3kTres Seaver2016-11-154-12/+23
| | | | | | | | | | | | | | | | | | | | - The bare import of '_zope_c_optimizations' prevented them from being used. - After enabling them via absolute imports, they would fail due to http://bugs.python.org/issue15657. Fixes #60.
* | Editing while reading: literals, typos, grammarJean Jordaan2016-10-161-1/+1
|/
* Fix equality testing of implementedBy objects that have been proxied. Fixes #55.fix-55Jason Madden2016-09-022-5/+46
|
* Support Components subclasses that are not hashable. (#54)Jason Madden2016-08-312-11/+31
| | | | | * Support Components subclasses that are not hashable. Fixes #53.
* Fix comment.Jason Madden2016-08-301-1/+1
|
* Better naming, and incorporate feedback from @prsephtonJason Madden2016-08-221-18/+19
|
* Use dictionary lookups for testing subscribed status.Jason Madden2016-08-192-74/+268
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Fixes #46. Benchmarks show a dramatic improvement; not quite as good as the demonstration in #46 because the implementation had to be a bit more complex to properly handle unregistration, but still very good. Here it is with 20,000 items already registered: ``` %time add_to_reg(reg, 1000) CPU times: user 190 ms, sys: 19.3 ms, total: 209 ms Wall time: 203 ms ``` Here's a profile with about 100,000 utilities registered: ``` %prun add_to_reg(reg, 1000) 80005 function calls (79005 primitive calls) in 0.713 seconds Ordered by: internal time ncalls tottime percall cumtime percall filename:lineno(function) 1000 0.596 0.001 0.621 0.001 adapter.py:202(subscribe) 12000 0.016 0.000 0.019 0.000 interface.py:518(__hash__) 1000 0.010 0.000 0.709 0.001 registry.py:206(registerUtility) 3000/2000 0.009 0.000 0.014 0.000 interface.py:255(interfaces) 2000 0.008 0.000 0.022 0.000 adapter.py:637(changed) 1000 0.008 0.000 0.025 0.000 registry.py:498(_getUtilityProvided) 9000 0.008 0.000 0.017 0.000 {method 'get' of 'dict' objects} 1000 0.008 0.000 0.027 0.000 adapter.py:102(register) 2000 0.006 0.000 0.008 0.000 adapter.py:450(changed) 1000 0.005 0.000 0.663 0.001 registry.py:145(registerUtility) ``` I was very careful not to change the pickle at all. zope.interface and zope.component tests have been run and both pass. (It was necessary to account for the underlying objects changing because of the way zope.component cleans up after tests.)
* Make declarations.Implements sortable.comp-implementsJason Madden2016-08-034-13/+103
| | | | Fixes #42
* Remove the _u compat function.literalsJason Madden2016-08-028-222/+214
| | | | | | Since we no longer support 3.2 we can use the literal syntax. This was done with a quick sed script.
* Remove duplicated linesGil Forcada2015-03-151-4/+0
| | | Commit https://github.com/zopefoundation/zope.interface/commit/bc3b946593fa204b1969d8785b58418adaa19c80 duplicated some lines on branch merge.
* Remove deprecated unittest assertions.Tres Seaver2014-12-278-742/+669
|
* 100% branch coverage.Tres Seaver2014-12-092-3/+3
| | | | | | We exclude interfaces declared with the 'class' statement, because their methods typically have only a doctstring in the suite, which confuses the branch coverage machinery.
* Normalize imports.Tres Seaver2014-12-091-3/+3
|