mirror of
https://github.com/mermaid-js/mermaid.git
synced 2025-11-15 18:24:33 +01:00
Added gitGraph jest test cases
This commit is contained in:
@@ -14,7 +14,6 @@ describe('when parsing a gitGraph', function() {
|
|||||||
parser.yy = gitGraphAst;
|
parser.yy = gitGraphAst;
|
||||||
parser.yy.clear();
|
parser.yy.clear();
|
||||||
randomNumber = 0;
|
randomNumber = 0;
|
||||||
|
|
||||||
});
|
});
|
||||||
// afterEach(function() {
|
// afterEach(function() {
|
||||||
// cryptoRandomString.mockReset();
|
// cryptoRandomString.mockReset();
|
||||||
@@ -145,6 +144,24 @@ describe('when parsing a gitGraph', function() {
|
|||||||
expect(commits[key].type).toBe(0);
|
expect(commits[key].type).toBe(0);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should handle a gitGraph commit with custom commit "msg:" key only', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit msg: "test commit"
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(1);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('master');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(1);
|
||||||
|
const key = Object.keys(commits)[0];
|
||||||
|
expect(commits[key].message).toBe('test commit');
|
||||||
|
expect(commits[key].id).not.toBeNull();
|
||||||
|
expect(commits[key].tag).toBe('');
|
||||||
|
expect(commits[key].type).toBe(0);
|
||||||
|
});
|
||||||
|
|
||||||
it('should handle a gitGraph commit with custom commit id, tag only', function () {
|
it('should handle a gitGraph commit with custom commit id, tag only', function () {
|
||||||
const str = `gitGraph:
|
const str = `gitGraph:
|
||||||
commit id:"1111" tag: "test tag"
|
commit id:"1111" tag: "test tag"
|
||||||
@@ -217,6 +234,180 @@ describe('when parsing a gitGraph', function() {
|
|||||||
expect(commits[key].type).toBe(1);
|
expect(commits[key].type).toBe(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should handle a gitGraph commit with custom commit id, type, tag and msg', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit id:"1111" type:REVERSE tag: "test tag" msg:"test msg"
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(1);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('master');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(1);
|
||||||
|
const key = Object.keys(commits)[0];
|
||||||
|
expect(commits[key].message).toBe('test msg');
|
||||||
|
expect(commits[key].id).toBe('1111');
|
||||||
|
expect(commits[key].tag).toBe('test tag');
|
||||||
|
expect(commits[key].type).toBe(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle a gitGraph commit with custom type,tag, msg, commit id,', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit type:REVERSE tag: "test tag" msg: "test msg" id: "1111"
|
||||||
|
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(1);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('master');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(1);
|
||||||
|
const key = Object.keys(commits)[0];
|
||||||
|
expect(commits[key].message).toBe('test msg');
|
||||||
|
expect(commits[key].id).toBe('1111');
|
||||||
|
expect(commits[key].tag).toBe('test tag');
|
||||||
|
expect(commits[key].type).toBe(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle a gitGraph commit with custom tag, msg, commit id, type,', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit tag: "test tag" msg:"test msg" id:"1111" type:REVERSE
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(1);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('master');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(1);
|
||||||
|
const key = Object.keys(commits)[0];
|
||||||
|
expect(commits[key].message).toBe('test msg');
|
||||||
|
expect(commits[key].id).toBe('1111');
|
||||||
|
expect(commits[key].tag).toBe('test tag');
|
||||||
|
expect(commits[key].type).toBe(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle a gitGraph commit with custom msg, commit id, type,tag', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit msg:"test msg" id:"1111" type:REVERSE tag: "test tag"
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(1);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('master');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(1);
|
||||||
|
const key = Object.keys(commits)[0];
|
||||||
|
expect(commits[key].message).toBe('test msg');
|
||||||
|
expect(commits[key].id).toBe('1111');
|
||||||
|
expect(commits[key].tag).toBe('test tag');
|
||||||
|
expect(commits[key].type).toBe(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle 3 straight commits', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit
|
||||||
|
commit
|
||||||
|
commit
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(3);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('master');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle new branch creation', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit
|
||||||
|
branch testBranch
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(1);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('master');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(2);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle new branch checkout', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit
|
||||||
|
branch testBranch
|
||||||
|
checkout testBranch
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(1);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('testBranch');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(2);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle new branch checkout & commit', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit
|
||||||
|
branch testBranch
|
||||||
|
checkout testBranch
|
||||||
|
commit
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(2);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('testBranch');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(2);
|
||||||
|
const commit1 = Object.keys(commits)[0];
|
||||||
|
const commit2 = Object.keys(commits)[1];
|
||||||
|
expect(commits[commit1].branch).toBe('master');
|
||||||
|
expect(commits[commit1].parents).toStrictEqual([]);
|
||||||
|
expect(commits[commit2].branch).toBe('testBranch');
|
||||||
|
expect(commits[commit2].parents).toStrictEqual([commit1]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle new branch checkout & commit and merge', function () {
|
||||||
|
const str = `gitGraph:
|
||||||
|
commit
|
||||||
|
branch testBranch
|
||||||
|
checkout testBranch
|
||||||
|
commit
|
||||||
|
commit
|
||||||
|
checkout master
|
||||||
|
merge testBranch
|
||||||
|
`;
|
||||||
|
|
||||||
|
parser.parse(str);
|
||||||
|
const commits = parser.yy.getCommits();
|
||||||
|
expect(Object.keys(commits).length).toBe(4);
|
||||||
|
expect(parser.yy.getCurrentBranch()).toBe('master');
|
||||||
|
expect(parser.yy.getDirection()).toBe('LR');
|
||||||
|
expect(Object.keys(parser.yy.getBranches()).length).toBe(2);
|
||||||
|
const commit1 = Object.keys(commits)[0];
|
||||||
|
const commit2 = Object.keys(commits)[1];
|
||||||
|
const commit3 = Object.keys(commits)[2];
|
||||||
|
const commit4 = Object.keys(commits)[3];
|
||||||
|
expect(commits[commit1].branch).toBe('master');
|
||||||
|
console.log(commits);
|
||||||
|
|
||||||
|
console.log(commits[commit1].parents);
|
||||||
|
expect(commits[commit1].parents).toStrictEqual([]);
|
||||||
|
expect(commits[commit2].branch).toBe('testBranch');
|
||||||
|
expect(commits[commit2].parents).toStrictEqual([commits[commit1].id]);
|
||||||
|
expect(commits[commit3].branch).toBe('testBranch');
|
||||||
|
expect(commits[commit3].parents).toStrictEqual([commits[commit2].id]);
|
||||||
|
expect(commits[commit4].branch).toBe('master');
|
||||||
|
expect(commits[commit4].parents).toStrictEqual([commits[commit1].id, commits[commit3].id]);
|
||||||
|
expect(parser.yy.getBranchesAsObjArray()).toStrictEqual([
|
||||||
|
{ name: 'master' },
|
||||||
|
{ name: 'testBranch' },
|
||||||
|
]);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user