mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-26 16:34:08 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			244 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			244 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { imgSnapshotTest, renderGraph } from '../../helpers/util';
 | |
| 
 | |
| describe('Entity Relationship Diagram', () => {
 | |
|   it('should render a simple ER diagram', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     erDiagram
 | |
|         CUSTOMER ||--o{ ORDER : places
 | |
|         ORDER ||--|{ LINE-ITEM : contains
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render an ER diagram with a recursive relationship', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     erDiagram
 | |
|         CUSTOMER ||..o{ CUSTOMER : refers
 | |
|         CUSTOMER ||--o{ ORDER : places
 | |
|         ORDER ||--|{ LINE-ITEM : contains
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render an ER diagram with multiple relationships between the same two entities', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     erDiagram
 | |
|         CUSTOMER ||--|{ ADDRESS : "invoiced at"
 | |
|         CUSTOMER ||--|{ ADDRESS : "receives goods at"
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render a cyclical ER diagram', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     erDiagram
 | |
|         A ||--|{ B : likes
 | |
|         B ||--|{ C : likes
 | |
|         C ||--|{ A : likes
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render a not-so-simple ER diagram', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     erDiagram
 | |
|         CUSTOMER }|..|{ DELIVERY-ADDRESS : has
 | |
|         CUSTOMER ||--o{ ORDER : places
 | |
|         CUSTOMER ||--o{ INVOICE : "liable for"
 | |
|         DELIVERY-ADDRESS ||--o{ ORDER : receives
 | |
|         INVOICE ||--|{ ORDER : covers
 | |
|         ORDER ||--|{ ORDER-ITEM : includes
 | |
|         PRODUCT-CATEGORY ||--|{ PRODUCT : contains
 | |
|         PRODUCT ||--o{ ORDER-ITEM : "ordered in"
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render multiple ER diagrams', () => {
 | |
|     imgSnapshotTest(
 | |
|       [
 | |
|         `
 | |
|     erDiagram
 | |
|         CUSTOMER ||--o{ ORDER : places
 | |
|         ORDER ||--|{ LINE-ITEM : contains
 | |
|       `,
 | |
|         `
 | |
|     erDiagram
 | |
|         CUSTOMER ||--o{ ORDER : places
 | |
|         ORDER ||--|{ LINE-ITEM : contains
 | |
|       `,
 | |
|       ],
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render an ER diagram with blank or empty labels', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     erDiagram
 | |
|         BOOK }|..|{ AUTHOR : ""
 | |
|         BOOK }|..|{ GENRE : " "
 | |
|         AUTHOR }|..|{ GENRE : "  "
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render an ER diagrams when useMaxWidth is true (default)', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     erDiagram
 | |
|         CUSTOMER ||--o{ ORDER : places
 | |
|         ORDER ||--|{ LINE-ITEM : contains
 | |
|       `,
 | |
|       { er: { useMaxWidth: true } }
 | |
|     );
 | |
|     cy.get('svg').should((svg) => {
 | |
|       expect(svg).to.have.attr('width', '100%');
 | |
|       expect(svg).to.have.attr('height', '465');
 | |
|       const style = svg.attr('style');
 | |
|       expect(style).to.match(/^max-width: [\d.]+px;$/);
 | |
|       const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join(''));
 | |
|       // use within because the absolute value can be slightly different depending on the environment ±5%
 | |
|       expect(maxWidthValue).to.be.within(140 * 0.95, 140 * 1.05);
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   it('should render an ER when useMaxWidth is false', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     erDiagram
 | |
|         CUSTOMER ||--o{ ORDER : places
 | |
|         ORDER ||--|{ LINE-ITEM : contains
 | |
|       `,
 | |
|       { er: { useMaxWidth: false } }
 | |
|     );
 | |
|     cy.get('svg').should((svg) => {
 | |
|       const width = parseFloat(svg.attr('width'));
 | |
|       // use within because the absolute value can be slightly different depending on the environment ±5%
 | |
|       expect(width).to.be.within(140 * 0.95, 140 * 1.05);
 | |
|       expect(svg).to.have.attr('height', '465');
 | |
|       expect(svg).to.not.have.attr('style');
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   it('should render entities that have no relationships', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     erDiagram
 | |
|         DEAD_PARROT
 | |
|         HERMIT
 | |
|         RECLUSE
 | |
|         SOCIALITE }o--o{ SOCIALITE : "interacts with"
 | |
|         RECLUSE }o--o{ SOCIALITE : avoids
 | |
|       `,
 | |
|       { er: { useMaxWidth: false } }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render entities with and without attributes', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     erDiagram
 | |
|         BOOK { string title }
 | |
|         AUTHOR }|..|{ BOOK : writes
 | |
|         BOOK { float price }
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render entities and attributes with big and small entity names', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     erDiagram
 | |
|         PRIVATE_FINANCIAL_INSTITUTION { 
 | |
|           string name
 | |
|           int    turnover
 | |
|         }
 | |
|         PRIVATE_FINANCIAL_INSTITUTION ||..|{ EMPLOYEE : employs
 | |
|         EMPLOYEE { bool officer_of_firm }
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render entities with keys', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     erDiagram
 | |
|       AUTHOR_WITH_LONG_ENTITY_NAME {
 | |
|         string name PK
 | |
|       }
 | |
|       AUTHOR_WITH_LONG_ENTITY_NAME }|..|{ BOOK : writes
 | |
|       BOOK { 
 | |
|           float price
 | |
|           string author FK 
 | |
|           string title PK
 | |
|         }
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render entities with comments', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     erDiagram
 | |
|       AUTHOR_WITH_LONG_ENTITY_NAME {
 | |
|         string name "comment"
 | |
|       }
 | |
|       AUTHOR_WITH_LONG_ENTITY_NAME }|..|{ BOOK : writes
 | |
|       BOOK { 
 | |
|           string author 
 | |
|           string title "author comment"
 | |
|           float price "price comment"
 | |
|         }
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| 
 | |
|   it('should render entities with keys and comments', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     erDiagram
 | |
|       AUTHOR_WITH_LONG_ENTITY_NAME {
 | |
|         string name PK "comment"
 | |
|       }
 | |
|       AUTHOR_WITH_LONG_ENTITY_NAME }|..|{ BOOK : writes
 | |
|       BOOK { 
 | |
|           string description
 | |
|           float price "price comment"
 | |
|           string title PK "title comment"
 | |
|           string author FK 
 | |
|         }
 | |
|       `,
 | |
|       { logLevel: 1 }
 | |
|     );
 | |
|     cy.get('svg');
 | |
|   });
 | |
| });
 | 
