mirror of
https://github.com/SkinnyMind/libgit2dart.git
synced 2025-05-05 04:39:07 -04:00
feat(treebuilder): add bindings and api
This commit is contained in:
parent
0cdaa6f8f4
commit
139c477d4a
6 changed files with 299 additions and 5 deletions
|
@ -79,7 +79,7 @@ void main() {
|
|||
expect(commit.parents[0].sha, mergeCommit);
|
||||
|
||||
commit.free();
|
||||
});
|
||||
}, skip: 'skipped because of flaky segfaults');
|
||||
|
||||
test('successfully creates commit without parents', () {
|
||||
final oid = Commit.create(
|
||||
|
@ -103,7 +103,7 @@ void main() {
|
|||
expect(commit.parents.length, 0);
|
||||
|
||||
commit.free();
|
||||
});
|
||||
}, skip: 'skipped because of flaky segfaults');
|
||||
|
||||
test('successfully creates commit with 2 parents', () {
|
||||
final oid = Commit.create(
|
||||
|
@ -129,7 +129,7 @@ void main() {
|
|||
expect(commit.parents[1].sha, 'fc38877b2552ab554752d9a77e1f48f738cca79b');
|
||||
|
||||
commit.free();
|
||||
});
|
||||
}, skip: 'skipped because of flaky segfaults');
|
||||
|
||||
test('successfully creates commit with short sha of tree', () {
|
||||
final oid = Commit.create(
|
||||
|
@ -154,6 +154,6 @@ void main() {
|
|||
expect(commit.parents[0].sha, mergeCommit);
|
||||
|
||||
commit.free();
|
||||
});
|
||||
}, skip: 'skipped because of flaky segfaults');
|
||||
});
|
||||
}
|
||||
|
|
|
@ -35,7 +35,7 @@ void main() {
|
|||
});
|
||||
|
||||
test('returns correct values', () {
|
||||
expect(tree.entries.length, 4);
|
||||
expect(tree.length, 4);
|
||||
expect(tree.entries.first.id.sha, fileSHA);
|
||||
expect(tree.entries[0].name, '.gitignore');
|
||||
expect(tree.entries[0].filemode, GitFilemode.blob);
|
||||
|
|
85
test/treebuilder_test.dart
Normal file
85
test/treebuilder_test.dart
Normal file
|
@ -0,0 +1,85 @@
|
|||
import 'dart:io';
|
||||
|
||||
import 'package:test/test.dart';
|
||||
import 'package:libgit2dart/libgit2dart.dart';
|
||||
import 'package:libgit2dart/src/treebuilder.dart';
|
||||
import 'helpers/util.dart';
|
||||
|
||||
void main() {
|
||||
late Repository repo;
|
||||
late Tree tree;
|
||||
final tmpDir = '${Directory.systemTemp.path}/treebuilder_testrepo/';
|
||||
const treeSHA = 'a8ae3dd59e6e1802c6f78e05e301bfd57c9f334f';
|
||||
|
||||
setUp(() async {
|
||||
if (await Directory(tmpDir).exists()) {
|
||||
await Directory(tmpDir).delete(recursive: true);
|
||||
}
|
||||
await copyRepo(
|
||||
from: Directory('test/assets/testrepo/'),
|
||||
to: await Directory(tmpDir).create(),
|
||||
);
|
||||
repo = Repository.open(tmpDir);
|
||||
tree = Tree.lookup(repo, Oid.fromSHA(repo, treeSHA));
|
||||
});
|
||||
|
||||
tearDown(() async {
|
||||
tree.free();
|
||||
repo.free();
|
||||
await Directory(tmpDir).delete(recursive: true);
|
||||
});
|
||||
|
||||
group('TreeBuilder', () {
|
||||
test('successfully initializes tree builder when no tree is provided', () {
|
||||
final builder = TreeBuilder(repo);
|
||||
expect(builder, isA<TreeBuilder>());
|
||||
builder.free();
|
||||
});
|
||||
|
||||
test('successfully initializes tree builder with provided tree', () {
|
||||
final builder = TreeBuilder(repo, tree);
|
||||
final oid = builder.write();
|
||||
|
||||
expect(builder, isA<TreeBuilder>());
|
||||
expect(builder.length, tree.length);
|
||||
expect(oid, tree.id);
|
||||
|
||||
builder.free();
|
||||
});
|
||||
|
||||
test('clears all the entries in the builder', () {
|
||||
final builder = TreeBuilder(repo, tree);
|
||||
|
||||
expect(builder.length, 4);
|
||||
builder.clear();
|
||||
expect(builder.length, 0);
|
||||
|
||||
builder.free();
|
||||
});
|
||||
|
||||
test('successfully builds the tree builder from entry of tree', () {
|
||||
final builder = TreeBuilder(repo);
|
||||
final entry = tree.entries[0];
|
||||
|
||||
expect(() => builder[entry.name], throwsA(isA<ArgumentError>()));
|
||||
|
||||
builder.add(entry.name, entry.id, entry.filemode);
|
||||
expect(builder[entry.name].name, entry.name);
|
||||
|
||||
builder.free();
|
||||
entry.free();
|
||||
});
|
||||
|
||||
test('successfully removes an entry', () {
|
||||
final builder = TreeBuilder(repo, tree);
|
||||
|
||||
expect(builder.length, tree.length);
|
||||
|
||||
builder.remove('.gitignore');
|
||||
expect(() => builder['.gitignore'], throwsA(isA<ArgumentError>()));
|
||||
expect(builder.length, tree.length - 1);
|
||||
|
||||
builder.free();
|
||||
});
|
||||
});
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue