소스 검색

Add HTML tests minus the substate

Marco Petersen 5 년 전
부모
커밋
737b9e4b88
1개의 변경된 파일630개의 추가작업 그리고 0개의 파일을 삭제
  1. 630 0
      src/twig/twig.test.ts

+ 630 - 0
src/twig/twig.test.ts

@@ -7,6 +7,636 @@
 
 import { testTokenization } from '../test/testRunner';
 
+/**
+ * HTML Tests, without the html substate
+ */
+testTokenization(['twig', 'css', 'javascript'], [
+
+	// Open Start Tag #1'
+	[{
+		line: '<abc',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' }
+		]
+	}],
+
+	// Open Start Tag #2
+	[{
+		line: '<input',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' }
+		]
+	}],
+
+	// Open Start Tag with Invalid Tag
+	[{
+		line: '< abc',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: '' }
+		]
+	}],
+
+	// Open Start Tag #3
+	[{
+		line: '< abc>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: '' }
+		]
+	}],
+
+	// Open Start Tag #4
+	[{
+		line: 'i <len;',
+		tokens: [
+			{ startIndex: 0, type: '' },
+			{ startIndex: 2, type: 'delimiter' },
+			{ startIndex: 3, type: 'tag' },
+			{ startIndex: 6, type: '' }
+		]
+	}],
+
+	// Open Start Tag #5
+	[{
+		line: '<',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' }
+		]
+	}],
+
+	// Open End Tag
+	[{
+		line: '</a',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 2, type: 'tag' }
+		]
+	}],
+
+	// Complete Start Tag
+	[{
+		line: '<abc>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: 'delimiter' }
+		]
+	}],
+
+	// Complete Start Tag with Whitespace
+	[{
+		line: '<abc >',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'delimiter' }
+		]
+	}],
+
+	// bug 9809 - Complete Start Tag with Namespaceprefix
+	[{
+		line: '<foo:bar>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 8, type: 'delimiter' }
+		]
+	}],
+
+	// Complete End Tag
+	[{
+		line: '</abc>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 2, type: 'tag' },
+			{ startIndex: 5, type: 'delimiter' }
+		]
+	}],
+
+	// Complete End Tag with Whitespace
+	[{
+		line: '</abc  >',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 2, type: 'tag' },
+			{ startIndex: 5, type: '' },
+			{ startIndex: 7, type: 'delimiter' }
+		]
+	}],
+
+	// Empty Tag
+	[{
+		line: '<abc />',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #1
+	[{
+		line: '<script type="text/javascript">var i= 10;</script>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: '' },
+			{ startIndex: 8, type: 'attribute.name' },
+			{ startIndex: 12, type: 'delimiter' },
+			{ startIndex: 13, type: 'attribute.value' },
+			{ startIndex: 30, type: 'delimiter' },
+			{ startIndex: 31, type: 'keyword.js' },
+			{ startIndex: 34, type: '' },
+			{ startIndex: 35, type: 'identifier.js' },
+			{ startIndex: 36, type: 'delimiter.js' },
+			{ startIndex: 37, type: '' },
+			{ startIndex: 38, type: 'number.js' },
+			{ startIndex: 40, type: 'delimiter.js' },
+			{ startIndex: 41, type: 'delimiter' },
+			{ startIndex: 43, type: 'tag' },
+			{ startIndex: 49, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #2
+	[{
+		line: '<script type="text/javascript">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: '' },
+			{ startIndex: 8, type: 'attribute.name' },
+			{ startIndex: 12, type: 'delimiter' },
+			{ startIndex: 13, type: 'attribute.value' },
+			{ startIndex: 30, type: 'delimiter' }
+		]
+	}, {
+		line: 'var i= 10;',
+		tokens: [
+			{ startIndex: 0, type: 'keyword.js' },
+			{ startIndex: 3, type: '' },
+			{ startIndex: 4, type: 'identifier.js' },
+			{ startIndex: 5, type: 'delimiter.js' },
+			{ startIndex: 6, type: '' },
+			{ startIndex: 7, type: 'number.js' },
+			{ startIndex: 9, type: 'delimiter.js' },
+		]
+	}, {
+		line: '</script>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 2, type: 'tag' },
+			{ startIndex: 8, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #3
+	[{
+		line: '<script type="text/javascript">var i= 10;',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: '' },
+			{ startIndex: 8, type: 'attribute.name' },
+			{ startIndex: 12, type: 'delimiter' },
+			{ startIndex: 13, type: 'attribute.value' },
+			{ startIndex: 30, type: 'delimiter' },
+			{ startIndex: 31, type: 'keyword.js' },
+			{ startIndex: 34, type: '' },
+			{ startIndex: 35, type: 'identifier.js' },
+			{ startIndex: 36, type: 'delimiter.js' },
+			{ startIndex: 37, type: '' },
+			{ startIndex: 38, type: 'number.js' },
+			{ startIndex: 40, type: 'delimiter.js' },
+
+		]
+	}, {
+		line: '</script>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 2, type: 'tag' },
+			{ startIndex: 8, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #4
+	[{
+		line: '<script type="text/javascript">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: '' },
+			{ startIndex: 8, type: 'attribute.name' },
+			{ startIndex: 12, type: 'delimiter' },
+			{ startIndex: 13, type: 'attribute.value' },
+			{ startIndex: 30, type: 'delimiter' }
+		]
+	}, {
+		line: 'var i= 10;</script>',
+		tokens: [
+			{ startIndex: 0, type: 'keyword.js' },
+			{ startIndex: 3, type: '' },
+			{ startIndex: 4, type: 'identifier.js' },
+			{ startIndex: 5, type: 'delimiter.js' },
+			{ startIndex: 6, type: '' },
+			{ startIndex: 7, type: 'number.js' },
+			{ startIndex: 9, type: 'delimiter.js' },
+			{ startIndex: 10, type: 'delimiter' },
+			{ startIndex: 12, type: 'tag' },
+			{ startIndex: 18, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #5
+	[{
+		line: '<script type="text/plain">a',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: '' },
+			{ startIndex: 8, type: 'attribute.name' },
+			{ startIndex: 12, type: 'delimiter' },
+			{ startIndex: 13, type: 'attribute.value' },
+			{ startIndex: 25, type: 'delimiter' },
+			{ startIndex: 26, type: '' },
+		]
+	}, {
+		line: '<a</script>',
+		tokens: [
+			{ startIndex: 0, type: '' },
+			{ startIndex: 2, type: 'delimiter' },
+			{ startIndex: 4, type: 'tag' },
+			{ startIndex: 10, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #6
+	[{
+		line: '<script>a</script><script>b</script>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: 'delimiter' },
+			{ startIndex: 8, type: 'identifier.js' },
+			{ startIndex: 9, type: 'delimiter' },
+			{ startIndex: 11, type: 'tag' },
+			{ startIndex: 17, type: 'delimiter' },
+			// { startIndex:18, type: 'delimiter' },
+			{ startIndex: 19, type: 'tag' },
+			{ startIndex: 25, type: 'delimiter' },
+			{ startIndex: 26, type: 'identifier.js' },
+			{ startIndex: 27, type: 'delimiter' },
+			{ startIndex: 29, type: 'tag' },
+			{ startIndex: 35, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #7
+	[{
+		line: '<script type="text/javascript"></script>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: '' },
+			{ startIndex: 8, type: 'attribute.name' },
+			{ startIndex: 12, type: 'delimiter' },
+			{ startIndex: 13, type: 'attribute.value' },
+			{ startIndex: 30, type: 'delimiter' },
+			// { startIndex:31, type: 'delimiter' },
+			{ startIndex: 33, type: 'tag' },
+			{ startIndex: 39, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #8
+	[{
+		line: '<script>var i= 10;</script>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: 'delimiter' },
+			{ startIndex: 8, type: 'keyword.js' },
+			{ startIndex: 11, type: '' },
+			{ startIndex: 12, type: 'identifier.js' },
+			{ startIndex: 13, type: 'delimiter.js' },
+			{ startIndex: 14, type: '' },
+			{ startIndex: 15, type: 'number.js' },
+			{ startIndex: 17, type: 'delimiter.js' },
+			{ startIndex: 18, type: 'delimiter' },
+			{ startIndex: 20, type: 'tag' },
+			{ startIndex: 26, type: 'delimiter' }
+		]
+	}],
+
+	// Embedded Content #9
+	[{
+		line: '<script type="text/javascript" src="main.js"></script>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 7, type: '' },
+			{ startIndex: 8, type: 'attribute.name' },
+			{ startIndex: 12, type: 'delimiter' },
+			{ startIndex: 13, type: 'attribute.value' },
+			{ startIndex: 30, type: '' },
+			{ startIndex: 31, type: 'attribute.name' },
+			{ startIndex: 34, type: 'delimiter' },
+			{ startIndex: 35, type: 'attribute.value' },
+			{ startIndex: 44, type: 'delimiter' },
+			// { startIndex:45, type: 'delimiter' },
+			{ startIndex: 47, type: 'tag' },
+			{ startIndex: 53, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Attribute
+	[{
+		line: '<abc foo="bar">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: 'delimiter' },
+			{ startIndex: 9, type: 'attribute.value' },
+			{ startIndex: 14, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Empty Attribute Value
+	[{
+		line: '<abc foo=\'bar\'>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: 'delimiter' },
+			{ startIndex: 9, type: 'attribute.value' },
+			{ startIndex: 14, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with empty attributes
+	[{
+		line: '<abc foo="">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: 'delimiter' },
+			{ startIndex: 9, type: 'attribute.value' },
+			{ startIndex: 11, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Attributes
+	[{
+		line: '<abc foo="bar" bar=\'foo\'>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: 'delimiter' },
+			{ startIndex: 9, type: 'attribute.value' },
+			{ startIndex: 14, type: '' },
+			{ startIndex: 15, type: 'attribute.name' },
+			{ startIndex: 18, type: 'delimiter' },
+			{ startIndex: 19, type: 'attribute.value' },
+			{ startIndex: 24, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Attributes, no quotes
+	[{
+		line: '<abc foo=bar bar=help-me>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: 'delimiter' },
+			{ startIndex: 9, type: 'attribute.name' }, // slightly incorrect
+			{ startIndex: 12, type: '' },
+			{ startIndex: 13, type: 'attribute.name' },
+			{ startIndex: 16, type: 'delimiter' },
+			{ startIndex: 17, type: 'attribute.name' }, // slightly incorrect
+			{ startIndex: 24, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Attribute And Whitespace
+	[{
+		line: '<abc foo=  "bar">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: 'delimiter' },
+			{ startIndex: 9, type: '' },
+			{ startIndex: 11, type: 'attribute.value' },
+			{ startIndex: 16, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Attribute And Whitespace #2
+	[{
+		line: '<abc foo = "bar">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: '' },
+			{ startIndex: 9, type: 'delimiter' },
+			{ startIndex: 10, type: '' },
+			{ startIndex: 11, type: 'attribute.value' },
+			{ startIndex: 16, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Name-Only-Attribute #1
+	[{
+		line: '<abc foo>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Name-Only-Attribute #2
+	[{
+		line: '<abc foo bar>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: '' },
+			{ startIndex: 9, type: 'attribute.name' },
+			{ startIndex: 12, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Interesting Attribute Name
+	[{
+		line: '<abc foo!@#="bar">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: '' },
+			{ startIndex: 11, type: 'delimiter' },
+			{ startIndex: 12, type: 'attribute.value' },
+			{ startIndex: 17, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Angular Attribute Name
+	[{
+		line: '<abc #myinput (click)="bar" [value]="someProperty" *ngIf="someCondition">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 6, type: 'attribute.name' },
+			{ startIndex: 13, type: '' },
+			{ startIndex: 15, type: 'attribute.name' },
+			{ startIndex: 20, type: '' },
+			{ startIndex: 21, type: 'delimiter' },
+			{ startIndex: 22, type: 'attribute.value' },
+			{ startIndex: 27, type: '' },
+			{ startIndex: 29, type: 'attribute.name' },
+			{ startIndex: 34, type: '' },
+			{ startIndex: 35, type: 'delimiter' },
+			{ startIndex: 36, type: 'attribute.value' },
+			{ startIndex: 50, type: '' },
+			{ startIndex: 52, type: 'attribute.name' },
+			{ startIndex: 56, type: 'delimiter' },
+			{ startIndex: 57, type: 'attribute.value' },
+			{ startIndex: 72, type: 'delimiter' }
+		]
+	}],
+
+	// Tag with Invalid Attribute Value
+	[{
+		line: '<abc foo=">',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 4, type: '' },
+			{ startIndex: 5, type: 'attribute.name' },
+			{ startIndex: 8, type: 'delimiter' },
+			{ startIndex: 9, type: '' },
+			{ startIndex: 10, type: 'delimiter' }
+		]
+	}],
+
+	// Simple Comment 1
+	[{
+		line: '<!--a-->',
+		tokens: [
+			{ startIndex: 0, type: 'comment' },
+			{ startIndex: 4, type: 'comment.content' },
+			{ startIndex: 5, type: 'comment' }
+		]
+	}],
+
+	// Simple Comment 2
+	[{
+		line: '<!--a>foo bar</a -->',
+		tokens: [
+			{ startIndex: 0, type: 'comment' },
+			{ startIndex: 4, type: 'comment.content' },
+			{ startIndex: 17, type: 'comment' }
+		]
+	}],
+
+	// Multiline Comment
+	[{
+		line: '<!--a>',
+		tokens: [
+			{ startIndex: 0, type: 'comment' },
+			{ startIndex: 4, type: 'comment.content' }
+		]
+	}, {
+		line: 'foo ',
+		tokens: [
+			{ startIndex: 0, type: 'comment.content' },
+		]
+	}, {
+		line: 'bar</a -->',
+		tokens: [
+			{ startIndex: 0, type: 'comment.content' },
+			{ startIndex: 7, type: 'comment' }
+		]
+	}],
+
+	// Simple Doctype
+	[{
+		line: '<!DOCTYPE a>',
+		tokens: [
+			{ startIndex: 0, type: 'metatag' },
+			{ startIndex: 9, type: 'metatag.content' },
+			{ startIndex: 11, type: 'metatag' }
+		]
+	}],
+
+	// Simple Doctype #2
+	[{
+		line: '<!doctype a>',
+		tokens: [
+			{ startIndex: 0, type: 'metatag' },
+			{ startIndex: 9, type: 'metatag.content' },
+			{ startIndex: 11, type: 'metatag' }
+		]
+	}],
+
+	// Simple Doctype #4
+	[{
+		line: '<!DOCTYPE a',
+		tokens: [
+			{ startIndex: 0, type: 'metatag' },
+			{ startIndex: 9, type: 'metatag.content' },
+		]
+	}, {
+		line: '"foo" \'bar\'>',
+		tokens: [
+			{ startIndex: 0, type: 'metatag.content' },
+			{ startIndex: 11, type: 'metatag' }
+		]
+	}],
+
+	// PR #14
+	[{
+		line: '<asdf:bar>asd</asdf:bar>',
+		tokens: [
+			{ startIndex: 0, type: 'delimiter' },
+			{ startIndex: 1, type: 'tag' },
+			{ startIndex: 9, type: 'delimiter' },
+			{ startIndex: 10, type: '' },
+			{ startIndex: 13, type: 'delimiter' },
+			{ startIndex: 15, type: 'tag' },
+			{ startIndex: 23, type: 'delimiter' }
+		]
+	}]
+]);
+
+/**
+ * Twig Tests
+ */
 testTokenization(['twig'], [
 	/**
 	 * Comments