Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 14 additions & 0 deletions 14 generate/input/descriptor.json
Original file line number Diff line number Diff line change
Expand Up @@ -1792,6 +1792,20 @@
},
"revert": {
"functions": {
"git_revert": {
"isAsync": true,
"return": {
"isErrorCode": true
}
},
"git_revert_commit": {
"isAsync": true,
"args": {
"merge_options": {
"isOptional": true
}
}
},
"git_revert_init_options": {
"ignore": true
}
Expand Down
47 changes: 47 additions & 0 deletions 47 lib/revert.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
var NodeGit = require("../");
var normalizeOptions = NodeGit.Utils.normalizeOptions;

var Revert = NodeGit.Revert;

/**
* Reverts the given commit against the given "our" commit, producing an index
* that reflects the result of the revert.
*
* @async
* @param {Repository} repo the repository that contains the given commits.
* @param {Commit} revert_commit the commit to revert
* @param {Commit} our_commit the commit to revert against (e.g. HEAD)
* @param {Number} mainline the parent of the revert commit, if it is a merge
* @param {MergeOptions} merge_options the merge options (or null for defaults)
*
* @return {Index} the index result
*/
var commit = Revert.commit;
Revert.commit = function(
repo,
revert_commit,
our_commit,
mainline,
merge_options,
callback
) {
merge_options = normalizeOptions(merge_options, NodeGit.MergeOptions);

return commit.call(
this,
repo,
revert_commit,
our_commit,
mainline,
merge_options
)
.then(function(result) {
if (typeof callback === "function") {
callback(null, result);
}

return result;
}, callback);
};

module.exports = Revert;
63 changes: 63 additions & 0 deletions 63 test/tests/revert.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
var _ = require("lodash");
var assert = require("assert");
var RepoUtils = require("../utils/repository_setup");
var path = require("path");
var fs = require("fs");
var local = path.join.bind(path, __dirname);

describe("Revert", function() {
var NodeGit = require("../../");

var Revert = NodeGit.Revert;
var RevertOptions = NodeGit.RevertOptions;

var test;
var fileName = "foobar.js";
var repoPath = local("../repos/revertRepo");

beforeEach(function() {
test = this;

return RepoUtils.createRepository(repoPath)
.then(function(repository) {
test.repository = repository;

return RepoUtils.commitFileToRepo(
repository,
fileName,
"line1\nline2\nline3"
);
})
.then(function(firstCommit) {
test.firstCommit = firstCommit;
});
});

it("revert modifies the working directoy", function() {
var fileStats = fs.statSync(path.join(repoPath, fileName));
assert.ok(fileStats.isFile());

Revert.revert(test.repository, test.firstCommit, new RevertOptions())
.then(function() {
try {
fs.statSync(path.join(repoPath, fileName));
assert.fail("Working directory was not reverted");
}
catch (error) {
// pass
}
});
});

it("revert modifies the index", function() {
Revert.revert(test.repository, test.firstCommit, new RevertOptions())
.then(function() {
return test.repository.index();
})
.then(function(index) {
var entries = index.entries;
assert.equal(1, entries.length);
assert.ok(_.endsWith(fileName, entries[0].path));
});
});
});
Morty Proxy This is a proxified and sanitized view of the page, visit original site.