Download images data aot for testing
This commit is contained in:
		
							parent
							
								
									6e41f85996
								
							
						
					
					
						commit
						e236a25da2
					
				
					 4 changed files with 35 additions and 12 deletions
				
			
		
							
								
								
									
										1
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							| 
						 | 
				
			
			@ -3,3 +3,4 @@ config.js
 | 
			
		|||
registration.yaml
 | 
			
		||||
coverage
 | 
			
		||||
db/ooye.db*
 | 
			
		||||
test/res/butterfly*
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,7 +1,7 @@
 | 
			
		|||
const assert = require("assert").strict
 | 
			
		||||
const {test} = require("supertape")
 | 
			
		||||
const {_convertImageStream} = require("./emoji-sheet")
 | 
			
		||||
const fetch = require("node-fetch")
 | 
			
		||||
const fs = require("fs")
 | 
			
		||||
const {Transform} = require("stream").Transform
 | 
			
		||||
 | 
			
		||||
/* c8 ignore next 7 */
 | 
			
		||||
| 
						 | 
				
			
			@ -25,18 +25,16 @@ class Meter extends Transform {
 | 
			
		|||
 | 
			
		||||
/**
 | 
			
		||||
 * @param {import("supertape").Test} t
 | 
			
		||||
 * @param {string} url
 | 
			
		||||
 * @param {string} path
 | 
			
		||||
 * @param {number} totalSize
 | 
			
		||||
 */
 | 
			
		||||
async function runSingleTest(t, url, totalSize) {
 | 
			
		||||
	const abortController = new AbortController()
 | 
			
		||||
	const res = await fetch("https://ezgif.com/images/format-demo/butterfly.png", {agent: false, signal: abortController.signal})
 | 
			
		||||
async function runSingleTest(t, path, totalSize) {
 | 
			
		||||
	const file = fs.createReadStream(path)
 | 
			
		||||
	const meter = new Meter()
 | 
			
		||||
	const p = res.body.pipe(meter)
 | 
			
		||||
	const p = file.pipe(meter)
 | 
			
		||||
	const result = await _convertImageStream(p, () => {
 | 
			
		||||
		abortController.abort()
 | 
			
		||||
		res.body.pause()
 | 
			
		||||
		res.body.emit("end")
 | 
			
		||||
		file.pause()
 | 
			
		||||
		file.emit("end")
 | 
			
		||||
	})
 | 
			
		||||
	t.equal(result.subarray(1, 4).toString("ascii"), "PNG", `result was not a PNG file: ${result.toString("base64")}`)
 | 
			
		||||
	/* c8 ignore next 5 */
 | 
			
		||||
| 
						 | 
				
			
			@ -48,9 +46,9 @@ async function runSingleTest(t, url, totalSize) {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
slow()("emoji-sheet: only partial file is read for APNG", async t => {
 | 
			
		||||
	await runSingleTest(t, "https://ezgif.com/images/format-demo/butterfly.png", 2438998)
 | 
			
		||||
	await runSingleTest(t, "test/res/butterfly.png", 2438998)
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
slow()("emoji-sheet: only partial file is read for GIF", async t => {
 | 
			
		||||
	await runSingleTest(t, "https://ezgif.com/images/format-demo/butterfly.gif", 781223)
 | 
			
		||||
	await runSingleTest(t, "test/res/butterfly.gif", 781223)
 | 
			
		||||
})
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -52,7 +52,7 @@
 | 
			
		|||
  "scripts": {
 | 
			
		||||
    "addbot": "node addbot.js",
 | 
			
		||||
    "test": "cross-env FORCE_COLOR=true supertape --no-check-assertions-count --format tap test/test.js | tap-dot",
 | 
			
		||||
    "test-slow": "cross-env FORCE_COLOR=true supertape --no-check-assertions-count --format tap test/test.js -- --slow | tap-dot",
 | 
			
		||||
    "test-slow": "cross-env FORCE_COLOR=true SUPERTAPE_TIMEOUT=6000 supertape --no-check-assertions-count --format tap test/test.js -- --slow | tap-dot",
 | 
			
		||||
    "cover": "c8 --skip-full -x db/migrations -x matrix/file.js -x matrix/api.js -x matrix/mreq.js -r html -r text supertape --no-check-assertions-count --format fail test/test.js -- --slow"
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										24
									
								
								test/test.js
									
										
									
									
									
								
							
							
						
						
									
										24
									
								
								test/test.js
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -7,6 +7,9 @@ const migrate = require("../db/migrate")
 | 
			
		|||
const HeatSync = require("heatsync")
 | 
			
		||||
const {test} = require("supertape")
 | 
			
		||||
const data = require("./data")
 | 
			
		||||
/** @type {import("node-fetch").default} */
 | 
			
		||||
// @ts-ignore
 | 
			
		||||
const fetch = require("node-fetch")
 | 
			
		||||
 | 
			
		||||
const config = require("../config")
 | 
			
		||||
const passthrough = require("../passthrough")
 | 
			
		||||
| 
						 | 
				
			
			@ -60,6 +63,27 @@ file._actuallyUploadDiscordFileToMxc = function(url, res) { throw new Error(`Not
 | 
			
		|||
	})
 | 
			
		||||
 | 
			
		||||
	db.exec(fs.readFileSync(join(__dirname, "ooye-test-data.sql"), "utf8"))
 | 
			
		||||
 | 
			
		||||
	/* c8 ignore start - maybe download some more test files in slow mode */
 | 
			
		||||
	if (process.argv.includes("--slow")) {
 | 
			
		||||
		test("test files: download", async t => {
 | 
			
		||||
			function download(url, to) {
 | 
			
		||||
				return new Promise(async resolve => {
 | 
			
		||||
					if (fs.existsSync(to)) return resolve(null)
 | 
			
		||||
					const res = await fetch(url)
 | 
			
		||||
					res.body.pipe(fs.createWriteStream(to, {encoding: "binary"}))
 | 
			
		||||
					res.body.once("finish", resolve)
 | 
			
		||||
				})
 | 
			
		||||
			}
 | 
			
		||||
			await Promise.all([
 | 
			
		||||
				download("https://ezgif.com/images/format-demo/butterfly.png", "test/res/butterfly.png"),
 | 
			
		||||
				download("https://ezgif.com/images/format-demo/butterfly.gif", "test/res/butterfly.gif")
 | 
			
		||||
			])
 | 
			
		||||
			t.pass("downloaded")
 | 
			
		||||
		})
 | 
			
		||||
	}
 | 
			
		||||
	/* c8 ignore end */
 | 
			
		||||
 | 
			
		||||
	require("../db/orm.test")
 | 
			
		||||
	require("../discord/utils.test")
 | 
			
		||||
	require("../matrix/kstate.test")
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue