libgit2dart/test/revwalk_test.dart
2021-10-22 15:10:04 +03:00

193 lines
4.6 KiB
Dart

import 'dart:ffi';
import 'dart:io';
import 'package:libgit2dart/libgit2dart.dart';
import 'package:test/test.dart';
import 'helpers/util.dart';
void main() {
late Repository repo;
late Directory tmpDir;
const log = [
'78b8bf123e3952c970ae5c1ce0a3ea1d1336f6e8',
'c68ff54aabf660fcdd9a2838d401583fe31249e3',
'fc38877b2552ab554752d9a77e1f48f738cca79b',
'6cbc22e509d72758ab4c8d9f287ea846b90c448b',
'f17d0d48eae3aa08cecf29128a35e310c97b3521',
];
setUp(() {
tmpDir = setupRepo(Directory('test/assets/testrepo/'));
repo = Repository.open(tmpDir.path);
});
tearDown(() {
repo.free();
tmpDir.deleteSync(recursive: true);
});
group('RevWalk', () {
test('successfully initializes', () {
final walker = RevWalk(repo);
expect(walker, isA<RevWalk>());
walker.free();
});
test('throws when trying to initialize and error occurs', () {
expect(
() => RevWalk(Repository(nullptr)),
throwsA(
isA<LibGit2Error>().having(
(e) => e.toString(),
'error',
"invalid argument: 'repo'",
),
),
);
});
test('returns list of commits with default sorting', () {
final walker = RevWalk(repo);
final start = Oid.fromSHA(repo: repo, sha: log.first);
walker.push(start);
final commits = walker.walk();
for (var i = 0; i < commits.length; i++) {
expect(commits[i].oid.sha, log[i]);
}
for (final c in commits) {
c.free();
}
walker.free();
});
test('returns list of commits with reverse sorting', () {
final walker = RevWalk(repo);
final start = Oid.fromSHA(repo: repo, sha: log.first);
walker.push(start);
walker.sorting({GitSort.reverse});
final commits = walker.walk();
for (var i = 0; i < commits.length; i++) {
expect(commits[i].oid.sha, log.reversed.toList()[i]);
}
for (final c in commits) {
c.free();
}
walker.free();
});
test('successfully changes sorting', () {
final walker = RevWalk(repo);
final start = Oid.fromSHA(repo: repo, sha: log.first);
walker.push(start);
final timeSortedCommits = walker.walk();
for (var i = 0; i < timeSortedCommits.length; i++) {
expect(timeSortedCommits[i].oid.sha, log[i]);
}
walker.sorting({GitSort.time, GitSort.reverse});
final reverseSortedCommits = walker.walk();
for (var i = 0; i < reverseSortedCommits.length; i++) {
expect(reverseSortedCommits[i].oid.sha, log.reversed.toList()[i]);
}
for (final c in timeSortedCommits) {
c.free();
}
for (final c in reverseSortedCommits) {
c.free();
}
walker.free();
});
test('successfully hides commit and its ancestors', () {
final walker = RevWalk(repo);
walker.push(repo[log.first]);
walker.hide(repo[log[2]]);
final commits = walker.walk();
expect(commits.length, 2);
for (final c in commits) {
c.free();
}
walker.free();
});
test('throws when trying to hide commit oid and error occurs', () {
final walker = RevWalk(repo);
expect(
() => walker.hide(repo['0' * 40]),
throwsA(
isA<LibGit2Error>().having(
(e) => e.toString(),
'error',
"odb: cannot read object: null OID cannot exist",
),
),
);
walker.free();
});
test('successfully resets walker', () {
final walker = RevWalk(repo);
final start = Oid.fromSHA(repo: repo, sha: log.first);
walker.push(start);
walker.reset();
final commits = walker.walk();
expect(commits, []);
walker.free();
});
test('simplifies walker by enqueuing only first parent for each commit',
() {
final walker = RevWalk(repo);
final start = Oid.fromSHA(repo: repo, sha: log.first);
walker.push(start);
walker.simplifyFirstParent();
final commits = walker.walk();
for (var i = 0; i < commits.length; i++) {
expect(commits.length, 3);
}
for (final c in commits) {
c.free();
}
walker.free();
});
test('throws when trying to add new root for traversal and error occurs',
() {
final walker = RevWalk(repo);
expect(
() => walker.push(repo['0' * 40]),
throwsA(
isA<LibGit2Error>().having(
(e) => e.toString(),
'error',
"odb: cannot read object: null OID cannot exist",
),
),
);
walker.free();
});
});
}