forked from MapComplete/MapComplete
		
	
		
			
	
	
		
			46 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			46 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| 
								 | 
							
								import {describe} from 'mocha'
							 | 
						||
| 
								 | 
							
								import {exec} from "child_process";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @param forbidden: a GREP-regex. This means that '.' is a wildcard and should be escaped to match a literal dot
							 | 
						||
| 
								 | 
							
								 * @param reason
							 | 
						||
| 
								 | 
							
								 * @private
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								function detectInCode(forbidden: string, reason: string) {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    const excludedDirs = [".git", "node_modules", "dist", ".cache", ".parcel-cache", "assets"]
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    exec("grep -n \"" + forbidden + "\" -r . " + excludedDirs.map(d => "--exclude-dir=" + d).join(" "), ((error, stdout, stderr) => {
							 | 
						||
| 
								 | 
							
								        if (error?.message?.startsWith("Command failed: grep")) {
							 | 
						||
| 
								 | 
							
								            console.warn("Command failed!")
							 | 
						||
| 
								 | 
							
								            return;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        if (error !== null) {
							 | 
						||
| 
								 | 
							
								            throw error
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        if (stderr !== "") {
							 | 
						||
| 
								 | 
							
								            throw stderr
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        const found = stdout.split("\n").filter(s => s !== "").filter(s => !s.startsWith("./tests/") && !s.startsWith("./testLegacy/"));
							 | 
						||
| 
								 | 
							
								        if (found.length > 0) {
							 | 
						||
| 
								 | 
							
								            throw `Found a '${forbidden}' at \n    ${found.join("\n     ")}.\n ${reason}`
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    }))
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								describe("Code quality", () => {
							 | 
						||
| 
								 | 
							
								    it("should not contain reverse", () => {
							 | 
						||
| 
								 | 
							
								        detectInCode("reverse()", "Reverse is stateful and changes the source list. This often causes subtle bugs")
							 | 
						||
| 
								 | 
							
								    })
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    it("should not contain 'constructor.name'", () => {
							 | 
						||
| 
								 | 
							
								        detectInCode("constructor\\.name", "This is not allowed, as minification does erase names.")
							 | 
						||
| 
								 | 
							
								    })
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								
							 |