vim/sadness/ropevim/src/rope/ropetest/contrib/changestacktest.py @ cffc630cdd07

Merge.
author Steve Losh <steve@stevelosh.com>
date Thu, 13 Jan 2011 00:02:54 -0500
parents 48cacfdc2ca6
children (none)
import unittest

import rope.base.history
import rope.contrib.changestack
from rope.base.change import *
from ropetest import testutils


class ChangeStackTest(unittest.TestCase):

    def setUp(self):
        super(ChangeStackTest, self).setUp()
        self.project = testutils.sample_project()

    def tearDown(self):
        testutils.remove_project(self.project)
        super(ChangeStackTest, self).tearDown()

    def test_change_stack(self):
        myfile = self.project.root.create_file('myfile.txt')
        myfile.write('1')
        stack = rope.contrib.changestack.ChangeStack(self.project)
        stack.push(ChangeContents(myfile, '2'))
        self.assertEquals('2', myfile.read())
        stack.push(ChangeContents(myfile, '3'))
        self.assertEquals('3', myfile.read())
        stack.pop_all()
        self.assertEquals('1', myfile.read())
        changes = stack.merged()
        self.project.do(changes)
        self.assertEquals('3', myfile.read())


if __name__ == '__main__':
    unittest.main()