added tests + alt syntax

This commit is contained in:
Christian Klemm 2019-10-04 23:49:58 +02:00
parent 912e850db4
commit 612df99c34
No known key found for this signature in database
GPG Key ID: 57578469FC907C48
4 changed files with 74 additions and 9 deletions

View File

@ -86,6 +86,7 @@ Future task2 : des4, after des3, 5d
```
classDiagram
Class01 <|-- AveryLongClass : Cool
<<interface>> Class01
Class03 *-- Class04
Class05 o-- Class06
Class07 .. Class08
@ -98,7 +99,11 @@ Class01 : size()
Class01 : int chimp
Class01 : int gorilla
Class08 <--> C2: Cool label
<<interface>> Class01
class Class10 {
<<service>>
int id
size()
}
```
![Class diagram](./img/class.png)

9
dist/index.html vendored
View File

@ -399,6 +399,7 @@ merge newbranch
<div class="mermaid">
classDiagram
Class01 <|-- AveryLongClass : Cool
&lt;&lt;interface&gt;&gt; Class01
Class03 "0" *-- "0..n" Class04
Class05 "1" o-- "many" Class06
Class07 .. Class08
@ -411,7 +412,11 @@ Class01 : size()
Class01 : int chimp
Class01 : int gorilla
Class08 <--> C2: Cool label
&lt;&lt;interface&gt;&gt; Class01
class Class10 {
&lt;&lt;service&gt;&gt;
int id
size()
}
</div>
<script src="./mermaid.js"></script>
<script>
@ -444,7 +449,7 @@ Class08 <--> C2: Cool label
const testLineEndings = (test, input) => {
try {
mermaid.render(test, input, () => {});
} catch (err) {
} catch (err) {
console.error("Error in %s:\n\n%s", test, err);
}
};

View File

@ -6,9 +6,6 @@ let classes = {};
/**
* Function called by parser when a node definition has been found.
* @param id
* @param text
* @param type
* @param style
*/
export const addClass = function(id) {
if (typeof classes[id] === 'undefined') {
@ -51,10 +48,13 @@ export const addAnnotation = function(className, annotation) {
export const addMember = function(className, member) {
const theClass = classes[className];
if (typeof member === 'string') {
if (member.substr(-1) === ')') {
theClass.methods.push(member);
const memberString = member.trim();
if (memberString.startsWith('<<') && memberString.endsWith('>>')) {
theClass.annotations.push(memberString.substring(2, memberString.length - 2));
} else if (memberString.endsWith(')')) {
theClass.methods.push(memberString);
} else {
theClass.members.push(member);
theClass.members.push(memberString);
}
}
};

View File

@ -207,5 +207,60 @@ describe('class diagram, ', function() {
expect(relations[3].relation.type2).toBe('none');
expect(relations[3].relation.lineType).toBe(classDb.lineType.DOTTED_LINE);
});
it('should handle class annotations', function() {
const str = 'classDiagram\n' + 'class Class1\n' + '<<interface>> Class1';
parser.parse(str);
const testClass = parser.yy.getClass('Class1');
expect(testClass.annotations.length).toBe(1);
expect(testClass.members.length).toBe(0);
expect(testClass.methods.length).toBe(0);
expect(testClass.annotations[0]).toBe('interface');
});
it('should handle class annotations with members and methods', function() {
const str =
'classDiagram\n' +
'class Class1\n' +
'Class1 : int test\n' +
'Class1 : test()\n' +
'<<interface>> Class1';
parser.parse(str);
const testClass = parser.yy.getClass('Class1');
expect(testClass.annotations.length).toBe(1);
expect(testClass.members.length).toBe(1);
expect(testClass.methods.length).toBe(1);
expect(testClass.annotations[0]).toBe('interface');
});
it('should handle class annotations in brackets', function() {
const str = 'classDiagram\n' + 'class Class1 {\n' + '<<interface>>\n' + '}';
parser.parse(str);
const testClass = parser.yy.getClass('Class1');
expect(testClass.annotations.length).toBe(1);
expect(testClass.members.length).toBe(0);
expect(testClass.methods.length).toBe(0);
expect(testClass.annotations[0]).toBe('interface');
});
it('should handle class annotations in brackets with members and methods', function() {
const str =
'classDiagram\n' +
'class Class1 {\n' +
'<<interface>>\n' +
'int : test\n' +
'test()\n' +
'}';
parser.parse(str);
const testClass = parser.yy.getClass('Class1');
expect(testClass.annotations.length).toBe(1);
expect(testClass.members.length).toBe(1);
expect(testClass.methods.length).toBe(1);
expect(testClass.annotations[0]).toBe('interface');
});
});
});