Security News
Maven Central Adds Sigstore Signature Validation
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.
Speccer provides simple means to test individual modules. It uses a minimal, assert-free syntax. This syntax is compiled to actual code utilizing Python's unittest. Henceforth Speccer may be seen as an alternative to it in various situations.
Run "setup.py install" to start rocking. See "demo" folder for an actual example. Once you have installed the tool just invoke "run_specs" at that directory. You should see some test results. Feel free to tweak the files to give it a proper go.
A module specification could look something like this:
myclass.spec: (tests myclass.py)
::
set up
c = myclass.MyClass()
adds two and two
c.add(2,2) == 4
adds negatives
c.add(10, -10) == 0
fails adding int and string
c.add(10, 'foo') raises TypeError
It looks pretty much like any other test you may have seen before. The syntax may be a bit lighter, though. As a test author you can focus on the essential while writing the assertions. In addition it's a bit nicer to read this way.
Note that it's possible to mix regular Python code within the tests. This might not work in all cases, though, and should be reported.
"set up" is a predefined test method that is run before each specification. This way you can set up some objects that are available for each test.
Each specification contains a name and some actual code asserting something. I have listed available assertions below:
, bigger than
=, bigger than or equal
These assertions map directly to ones available in Python's unittest module. If some of those seem weird to you, see http://docs.python.org/library/unittest.html .
Speccer is available under MIT license. See LICENSE for more details.
FAQs
Specification based test runner.
We found that speccer demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.
Security News
CISOs are racing to adopt AI for cybersecurity, but hurdles in budgets and governance may leave some falling behind in the fight against cyber threats.
Research
Security News
Socket researchers uncovered a backdoored typosquat of BoltDB in the Go ecosystem, exploiting Go Module Proxy caching to persist undetected for years.