##// END OF EJS Templates
Merge pull request #3780 from damianavila/reveal_writer...
Merge pull request #3780 from damianavila/reveal_writer Added serving the output directory if html-based format are selected.

File last commit:

r11131:ad2364d8
r11829:c6497ff5 merge
Show More
test_kill_ring.py
85 lines | 2.2 KiB | text/x-python | PythonLexer
epatters
Add Emacs-style kill ring to Qt console....
r3767 # Standard library imports
import unittest
# System library imports
Thomas Kluyver
Remove unused imports in IPython.qt
r11131 from IPython.external.qt import QtGui
epatters
Add Emacs-style kill ring to Qt console....
r3767
# Local imports
Fernando Perez
Fix all remaining imports that used `IPython.frontend`.
r11024 from IPython.qt.console.kill_ring import KillRing, QtKillRing
epatters
Add Emacs-style kill ring to Qt console....
r3767
class TestKillRing(unittest.TestCase):
@classmethod
def setUpClass(cls):
""" Create the application for the test case.
"""
Puneeth Chaganti
TST: QApplication doesn't quit early enough with PySide....
r6574 cls._app = QtGui.QApplication.instance()
if cls._app is None:
cls._app = QtGui.QApplication([])
epatters
Add Emacs-style kill ring to Qt console....
r3767 cls._app.setQuitOnLastWindowClosed(False)
@classmethod
def tearDownClass(cls):
""" Exit the application.
"""
QtGui.QApplication.quit()
def test_generic(self):
""" Does the generic kill ring work?
"""
ring = KillRing()
Bradley M. Froehle
s/assert_/assertTrue/
r7876 self.assertTrue(ring.yank() is None)
self.assertTrue(ring.rotate() is None)
epatters
Add Emacs-style kill ring to Qt console....
r3767
ring.kill('foo')
self.assertEqual(ring.yank(), 'foo')
Bradley M. Froehle
s/assert_/assertTrue/
r7876 self.assertTrue(ring.rotate() is None)
epatters
Add Emacs-style kill ring to Qt console....
r3767 self.assertEqual(ring.yank(), 'foo')
ring.kill('bar')
self.assertEqual(ring.yank(), 'bar')
self.assertEqual(ring.rotate(), 'foo')
ring.clear()
Bradley M. Froehle
s/assert_/assertTrue/
r7876 self.assertTrue(ring.yank() is None)
self.assertTrue(ring.rotate() is None)
epatters
Add Emacs-style kill ring to Qt console....
r3767
def test_qt_basic(self):
""" Does the Qt kill ring work?
"""
text_edit = QtGui.QPlainTextEdit()
ring = QtKillRing(text_edit)
ring.kill('foo')
ring.kill('bar')
ring.yank()
ring.rotate()
ring.yank()
self.assertEqual(text_edit.toPlainText(), 'foobar')
text_edit.clear()
ring.kill('baz')
ring.yank()
ring.rotate()
ring.rotate()
ring.rotate()
self.assertEqual(text_edit.toPlainText(), 'foo')
def test_qt_cursor(self):
""" Does the Qt kill ring maintain state with cursor movement?
"""
text_edit = QtGui.QPlainTextEdit()
ring = QtKillRing(text_edit)
ring.kill('foo')
ring.kill('bar')
ring.yank()
text_edit.moveCursor(QtGui.QTextCursor.Left)
ring.rotate()
self.assertEqual(text_edit.toPlainText(), 'bar')
if __name__ == '__main__':
import nose
nose.main()