nci/test/scm.js

131 lines
3.6 KiB
JavaScript
Raw Normal View History

'use strict';
var expect = require('expect.js'),
2015-06-28 10:04:36 +00:00
_ = require('underscore'),
path = require('path'),
fs = require('fs'),
2014-05-10 10:19:47 +00:00
createScm = require('../lib/scm').createScm,
2015-06-23 19:18:13 +00:00
SpawnCommand = require('../lib/command/spawn').Command,
mercurialRevs = require('./helpers').mercurialRevs;
['mercurial'].forEach(function(type) {
describe(type, function() {
var data = getTestData(type),
repositoryName = 'test-repository',
repositoryPath = path.join(path.join(__dirname, 'repos'), repositoryName);
2014-05-10 10:19:47 +00:00
function rmdir(dir, callback) {
2014-12-02 21:09:05 +00:00
new SpawnCommand().run({cmd: 'rm', args: ['-R', dir]}, callback);
2014-05-10 10:19:47 +00:00
}
it('remove test repository dir if it exists', function(done) {
if (fs.exists(repositoryPath, function(isExists) {
if (isExists) {
2014-05-10 10:19:47 +00:00
rmdir(repositoryPath, done);
} else {
done();
}
}));
});
2014-05-10 09:36:07 +00:00
var scm;
it('create scm instance attached to new repository without errors', function() {
scm = createScm({
type: type,
repository: path.join(__dirname, 'repos', type)
});
});
2015-06-23 19:18:13 +00:00
var currentRev = data[0].id;
it('clone rev0 to dst without errors', function(done) {
2015-06-23 19:18:13 +00:00
scm.clone(repositoryPath, data[0].id, done);
});
it('expect scm.cwd equals to dst', function() {
expect(scm.cwd).equal(repositoryPath);
});
it('expect current revision equals to rev0', function(done) {
scm.getCurrent(function(err, rev) {
if (err) return done(err);
2015-06-28 10:04:36 +00:00
// there is no tag for mercurial repo coz when you clone with
// specified revision no later revision will be cloned
// including those one with add tag (it's after rev 0 in our
// repo)
expect(rev).eql(_(data[0]).omit('tags'));
2015-06-23 19:18:13 +00:00
done();
});
});
it('expect rev0 info is good', function(done) {
scm.getRev(mercurialRevs[0].id, function(err, rev) {
if (err) return done(err);
2015-06-28 10:04:36 +00:00
// no tag here, see note above
expect(rev).eql(_(data[0]).omit('tags'));
done();
});
});
it('expect none changes from rev0 to default revision', function(done) {
2015-06-23 19:18:13 +00:00
scm.getChanges(data[0].id, scm.defaultRev, function(err, changes) {
if (err) return done(err);
expect(changes).ok();
expect(changes).length(0);
done();
});
});
it('pull to default revision without errors', function(done) {
scm.pull(scm.defaultRev, done);
});
it('now (after pull) expect all after rev 0 as new changes (in reverse ' +
'order) from rev0 to default revision', function(done) {
2015-06-23 19:18:13 +00:00
scm.getChanges(data[0].id, scm.defaultRev, function(err, changes) {
if (err) return done(err);
expect(changes).ok();
expect(changes).eql(data.slice(1).reverse());
done();
});
});
it('update to default revision (should update to last) without error',
function(done) {
scm.update(scm.defaultRev, done);
});
it('expect current revision equals to last', function(done) {
scm.getCurrent(function(err, rev) {
if (err) return done(err);
expect(rev).eql(data[data.length - 1]);
done();
});
});
2014-05-10 09:36:07 +00:00
it('create scm instance attached to existing `cwd` without errors', function() {
scm = createScm({type: type, cwd: repositoryPath});
});
it('expect repository log from rev0 to default revision equals to ' +
'all revs followed by rev 0 (in reverse order)', function(done) {
2015-06-23 19:18:13 +00:00
scm.getChanges(data[0].id, scm.defaultRev, function(err, changes) {
2014-05-10 09:36:07 +00:00
if (err) return done(err);
expect(changes).ok();
expect(changes).eql(data.slice(1).reverse());
2014-05-10 09:36:07 +00:00
done();
});
});
it('remove test repository dir', function(done) {
2014-05-10 10:19:47 +00:00
rmdir(repositoryPath, done);
});
});
});
function getTestData(type) {
2015-06-23 19:18:13 +00:00
if (type === 'mercurial') return mercurialRevs;
}