Files
MacPass/MacPassTests/KPKTestUndo.m
2015-10-23 19:29:47 +02:00

279 lines
10 KiB
Objective-C

//
// KPKUndo.m
// MacPass
//
// Created by Michael Starke on 04/08/15.
// Copyright (c) 2015 HicknHack Software GmbH. All rights reserved.
//
#import <Cocoa/Cocoa.h>
#import <XCTest/XCTest.h>
#import "KPKTree.h"
#import "KPKGroup.h"
#import "KPKEntry.h"
@interface KPKTestUndo : XCTestCase <KPKTreeDelegate> {
NSUndoManager *_undoManager;
KPKTree *_tree;
KPKGroup *_root, *_groupA, *_groupB;
KPKEntry *_entryA, *_entryB;
}
@end
@implementation KPKTestUndo
- (NSUndoManager *)undoManagerForTree:(KPKTree *)tree {
return _undoManager;
}
- (void)setUp {
[super setUp];
_undoManager = [[NSUndoManager alloc] init];
_tree = [[KPKTree alloc] init];
_tree.delegate = self;
/* Disable undo registration in the setup to have a clean test environment */
[_undoManager disableUndoRegistration];
_root = [[KPKGroup alloc] init];
_tree.root = _root;
_groupA = [[KPKGroup alloc] init];
_groupA.title = @"Group A";
_groupB = [[KPKGroup alloc] init];
_groupB.title = @"Group B";
[_root addGroup:_groupA];
[_root addGroup:_groupB];
_entryA = [[KPKEntry alloc] init];
_entryA.title = @"Entry A";
_entryA.username = @"Username A";
_entryA.url = @"http://www.a.com";
[_groupA addEntry:_entryA];
_entryB = [[KPKEntry alloc] init];
_entryB.title = @"Entry B";
_entryB.username = @"Username B";
_entryB.url = @"http://www.b.com";
[_groupB addEntry:_entryB];
/* Enable undo registration for the tests */
[_undoManager enableUndoRegistration];
}
- (void)tearDown {
_entryA = nil;
_entryB = nil;
_groupB = nil;
_groupA = nil;
_tree = nil;
_undoManager = nil;
[super tearDown];
}
- (void)testUndoRedoCreateEntry {
XCTAssertFalse(_undoManager.canUndo, @"Undo stack is empty");
XCTAssertFalse(_undoManager.canRedo, @"Redo stack is empty");
KPKEntry *entry = [_tree createEntry:_groupA];
[_groupA addEntry:entry];
XCTAssertEqual(_groupA.entries.count, 2, @"Group A has two entries");
XCTAssertTrue([_groupA.entries containsObject:entry], @"Created entry is in group A");
XCTAssertEqual(_groupB.entries.count, 1, @"Group B has one entry");
XCTAssertFalse([_groupB.entries containsObject:entry], @"Created entry is not in group B");
XCTAssertEqual(_root.entries.count, 0, @"Root has no entries");
XCTAssertFalse([_root.entries containsObject:entry], @"Created entry is not in root group");
XCTAssertTrue(_undoManager.canUndo, @"Undomanager can undo");
[_undoManager undo];
XCTAssertEqual(_groupA.entries.count, 1, @"Group A has one entry after undo");
XCTAssertFalse([_groupA.entries containsObject:entry], @"Created enty is not in group A");
XCTAssertEqual(_groupB.entries.count, 1, @"Group B has one entry");
XCTAssertFalse([_groupB.entries containsObject:entry], @"Created enty is not in group A");
XCTAssertEqual(_root.entries.count, 0, @"Root has no entries");
XCTAssertFalse([_root.entries containsObject:entry], @"Created enty is not in group A");
XCTAssertFalse(_undoManager.canUndo, @"Undomanager cannot undo anymore");
XCTAssertTrue(_undoManager.canRedo, @"Undomanger can redo executed undo");
[_undoManager redo];
XCTAssertEqual(_groupA.entries.count, 2, @"Group A has two entries");
XCTAssertTrue([_groupA.entries containsObject:entry], @"Created entry is in group A");
XCTAssertEqual(_groupB.entries.count, 1, @"Group B has one entry");
XCTAssertFalse([_groupB.entries containsObject:entry], @"Created entry is not in group B");
XCTAssertEqual(_root.entries.count, 0, @"Root has no entries");
XCTAssertFalse([_root.entries containsObject:entry], @"Created entry is not in root group");
XCTAssertTrue(_undoManager.canUndo, @"Undomanager can undo again after redo");
XCTAssertFalse(_undoManager.canRedo, @"Undomanger cannot redo after redo");
}
- (void)testUndoRedoCreateGroup {
XCTFail(@"Missing Test");
}
- (void)testUndoRedoMoveEntry {
XCTAssertFalse(_undoManager.canUndo, @"Undo stack is empty");
XCTAssertFalse(_undoManager.canRedo, @"Redo stack is empty");
XCTAssertEqual(_groupA.entries.count, 1, @"Group A has one entry");
XCTAssertTrue([_groupA.entries containsObject:_entryA], @"Entry A is in group A");
XCTAssertEqual(_groupB.entries.count, 1, @"Group B has one entry");
XCTAssertTrue([_groupB.entries containsObject:_entryB], @"Entry B is in group B");
XCTAssertEqual(_root.entries.count, 0, @"Root has no entries");
XCTAssertFalse([_root.entries containsObject:_entryB], @"Entry A is not in root group");
XCTAssertFalse([_root.entries containsObject:_entryA], @"Entry A is not in root group");
[_entryA moveToGroup:_groupB];
XCTAssertEqual(_groupA.entries.count, 0, @"Group A has no entries");
XCTAssertEqual(_groupB.entries.count, 2, @"Group B has two entries");
XCTAssertTrue([_groupB.entries containsObject:_entryA], @"Entry A is moved to group B");
XCTAssertTrue([_groupB.entries containsObject:_entryB], @"Entry B is in group B");
XCTAssertEqual(_root.entries.count, 0, @"Root has no entries");
XCTAssertFalse([_root.entries containsObject:_entryB], @"Entry A is not in root group");
XCTAssertFalse([_root.entries containsObject:_entryA], @"Entry A is not in root group");
XCTAssertTrue(_undoManager.canUndo, @"Undomanager can undo");
XCTAssertFalse(_undoManager.canRedo, @"Undomanager still cannot redo");
[_undoManager undo];
XCTAssertEqual(_groupA.entries.count, 1, @"Group A has one entry after undo");
XCTAssertTrue([_groupA.entries containsObject:_entryA], @"Entry A is in group A after undo");
XCTAssertEqual(_groupB.entries.count, 1, @"Group B has one entry after undo");
XCTAssertTrue([_groupB.entries containsObject:_entryB], @"Entry B is in group B after undo");
XCTAssertEqual(_root.entries.count, 0, @"Root has no entries");
XCTAssertFalse([_root.entries containsObject:_entryA], @"Entry A is not in root group after undo");
XCTAssertFalse([_root.entries containsObject:_entryB], @"Entry B is not in root group after undo");
XCTAssertFalse(_undoManager.canUndo, @"Undomanager cannot undo anymore");
XCTAssertTrue(_undoManager.canRedo, @"Undomanger can redo executed undo");
[_undoManager redo];
XCTAssertEqual(_groupA.entries.count, 0, @"Group A has no entries after redo");
XCTAssertEqual(_groupB.entries.count, 2, @"Group B has two entries");
XCTAssertTrue([_groupB.entries containsObject:_entryA], @"Entry A is moved to group B after redo");
XCTAssertTrue([_groupB.entries containsObject:_entryB], @"Entry B is in group B");
XCTAssertEqual(_root.entries.count, 0, @"Root has no entries");
XCTAssertFalse([_root.entries containsObject:_entryA], @"Entry A is not in root group after redo");
XCTAssertFalse([_root.entries containsObject:_entryB], @"Entry B is not in root group after redo");
XCTAssertTrue(_undoManager.canUndo, @"Undomanager can undo again after redo");
XCTAssertFalse(_undoManager.canRedo, @"Undomanager cannot redo anymore after redo");
}
- (void)testUndoRedoMoveGroup {
XCTAssertFalse(_undoManager.canUndo, @"Undo stack is empty");
XCTAssertFalse(_undoManager.canRedo, @"Redo stack is empty");
XCTAssertEqual(_groupA.groups.count, 0, @"Group A has no child groups");
XCTAssertEqual(_groupB.groups.count, 0, @"Group B has no child groups");
XCTAssertEqual(_root.groups.count, 2, @"Root has two child groups");
XCTAssertTrue([_root.groups containsObject:_groupA], @"Group A is in root group");
XCTAssertTrue([_root.groups containsObject:_groupB], @"Group B is in root group");
[_groupA moveToGroup:_groupB];
XCTAssertTrue(_undoManager.canUndo, @"Undomanager can undo after move");
XCTAssertFalse(_undoManager.canRedo, @"Redo stack is still empty");
XCTAssertEqual(_groupA.groups.count, 0, @"Group A has no child groups");
XCTAssertEqual(_groupB.groups.count, 1, @"Group B has one child group");
XCTAssertTrue([_groupB.groups containsObject:_groupA], @"Group A is child group of Group B");
XCTAssertEqual(_groupB, _groupA.parent, @"Group B is parent of Group A");
XCTAssertEqual(_root.groups.count, 1, @"Root has one child group");
XCTAssertFalse([_root.groups containsObject:_groupA], @"Group A is not root group");
XCTAssertTrue([_root.groups containsObject:_groupB], @"Group B is in root group");
[_undoManager undo];
XCTAssertFalse(_undoManager.canUndo, @"Undo stack is empty after undo");
XCTAssertTrue(_undoManager.canRedo, @"Undomanager can redo after undo");
XCTAssertEqual(_groupA.groups.count, 0, @"Group A has no child groups after undo");
XCTAssertEqual(_groupB.groups.count, 0, @"Group B has no child groups after undo");
XCTAssertEqual(_root, _groupA.parent, @"Root is parent of Group A after undo");
XCTAssertEqual(_root, _groupB.parent, @"Root is parent of Group B after undo");
XCTAssertEqual(_root.groups.count, 2, @"Root has two child groups after undo");
XCTAssertTrue([_root.groups containsObject:_groupA], @"Group A is in root group after undo");
XCTAssertTrue([_root.groups containsObject:_groupB], @"Group B is in root group after undo");
[_undoManager redo];
XCTAssertTrue(_undoManager.canUndo, @"Undomanager can undo again after redo");
XCTAssertFalse(_undoManager.canRedo, @"Redo stack is empty after redo");
XCTAssertEqual(_groupA.groups.count, 0, @"Group A has no child groups after redo");
XCTAssertEqual(_groupB.groups.count, 1, @"Group B has one child group after redo");
XCTAssertTrue([_groupB.groups containsObject:_groupA], @"Group A is child group of Group B after redo");
XCTAssertEqual(_groupB, _groupA.parent, @"Group B is parent of Group A after redo");
XCTAssertEqual(_root.groups.count, 1, @"Root has one child group after redo");
XCTAssertFalse([_root.groups containsObject:_groupA], @"Group A is not root group after redo");
XCTAssertTrue([_root.groups containsObject:_groupB], @"Group B is in root group after redo");
}
- (void)testUndoRedoReorderGroups {
XCTFail(@"Missing test");
}
- (void)testUndoRedoDeleteGroupWithoutTrash {
/* TODO: Deleting groups needs to be moved from MPDocument to KeePassKit */
XCTFail(@"Missing test");
}
- (void)testUndoRedoDeleteEntryWithoutTrash {
/* TODO: Deleting entries needs to be moved from MPDocument to KeePassKit */
XCTFail(@"Missing test");
}
- (void)testUndoRedoDeleteGroupWithTrash {
XCTFail(@"Missing test");
}
- (void)testUndoRedoDeleteEntryWithTrash {
XCTFail(@"Missing test");
}
- (void)testUndoRedoEditEntry {
XCTFail(@"Missing test");
}
- (void)testUndoRedoEditGroup {
XCTFail(@"Missing test");
}
@end