ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

Rocks

by jonesambrosi ALL

This project have continuous integration testing for automating code coverage in realtime for Python on SublimeText. This plugin simplify development process and check more quickly the problems

Details

Installs

  • Total 62
  • Win 33
  • Mac 14
  • Linux 15
Jan 15 Jan 14 Jan 13 Jan 12 Jan 11 Jan 10 Jan 9 Jan 8 Jan 7 Jan 6 Jan 5 Jan 4 Jan 3 Jan 2 Jan 1 Dec 31 Dec 30 Dec 29 Dec 28 Dec 27 Dec 26 Dec 25 Dec 24 Dec 23 Dec 22 Dec 21 Dec 20 Dec 19 Dec 18 Dec 17 Dec 16 Dec 15 Dec 14 Dec 13 Dec 12 Dec 11 Dec 10 Dec 9 Dec 8 Dec 7 Dec 6 Dec 5 Dec 4 Dec 3 Dec 2
Windows 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Mac 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Linux 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

Rocks

This project have continuous integration testing for automating code coverage in realtime for Python on SublimeText. This plugin simplify development process and check more quickly the problems.

This project is inspired in NCrunch plugin for VS Studio. Not finded similar projects for python.

UI:

Example

Use Rocks.tmTheme to view color in icons. If you use a another theme, please add this lines in tmTheme file used.

... 
    <string>Sunburst</string>
    <key>settings</key>
    <array>
... 


<dict>
    <key>name</key>
    <string>markup.tracked.rocks</string>
    <key>scope</key>
    <string>markup.tracked.rocks</string>
    <key>settings</key>
    <dict>
        <key>foreground</key>
        <string>#41a017</string>
    </dict>
</dict>
<dict>
    <key>name</key>
    <string>markup.untracked.rocks</string>
    <key>scope</key>
    <string>markup.untracked.rocks</string>
    <key>settings</key>
    <dict>
        <key>foreground</key>
        <string>#AAAAAA</string>
    </dict>
</dict>
<dict>
    <key>name</key>
    <string>markup.skipped.rocks</string>
    <key>scope</key>
    <string>markup.skipped.rocks</string>
    <key>settings</key>
    <dict>
        <key>foreground</key>
        <string>#FFF380</string>
    </dict>
</dict>
<dict>
    <key>name</key>
    <string>markup.error.rocks</string>
    <key>scope</key>
    <string>markup.error.rocks</string>
    <key>settings</key>
    <dict>
        <key>foreground</key>
        <string>#FF0000</string>
    </dict>
</dict>

... 
</array>

Features proposed

Release 1 - Done

  • Auto detect code coverage
  • Better UI to detect coverage inconsistences

Release 2

  • Detect impact of code and importance of system
  • Metrics for development
  • Simple navigation in issues detected

Release 3

  • Integration of linty system
  • Suggestions refactories

Future relases

  • Distributing testing
  • Integration of test systems (tox, nunit, etc)

Limitations

  • Coverage tests not work in Django projects.

Examples

File class_a.py

import time


class A(object):

    def __init__(self):
        self.value = "Some Value"

    def return_true(self):
        return True

    def raise_exc(self, val):

        if val == "TDD":
            return True

        raise ValueError(val)

    def repeat(self):
        return 1

    def sleeping_half_second(self):
        time.sleep(0.5)  # Warning running, show extra info warning

    def sleeping(self):
        time.sleep(1)  # Long running, show extra info slow

    def sleeping_more_one_seconds(self):
        # Long running greater than 1 seconds, show extra info slower
        time.sleep(1.1)

File test_coverage.py

import unittest
from class_a import A


class TestSimple(unittest.TestCase):
    """Simple test coverage"""

    def test_pass(self):
        assert True

    # def test_fail(self):
    #     assert False

    # def test_fail_2(self):
    #     assert 2 == 1

    def test_init(self):
        a = A()

        assert a.return_true()

    def test_sleeping_half_second(self):
        a = A()
        a.sleeping_half_second()

        assert True

    def test_sleeping(self):
        a = A()
        a.sleeping()

        assert True

    def test_sleeping_more_one_seconds(self):
        a = A()
        a.sleeping_more_one_seconds()

        assert True

    def test_exception(self):
        a = A()

        assert a.raise_exc("DDD")

        return

        # Check code not reached in coverage
        d = 1 + 2 + 3