simplify
This commit is contained in:
@@ -4,45 +4,45 @@ import fs from 'fs';
|
||||
import path from 'path';
|
||||
|
||||
describe('Icon 512x512 Generation', () => {
|
||||
const iconPath = path.resolve('static/icon-512.png');
|
||||
const iconPath = path.resolve('static/icon-512.png');
|
||||
|
||||
it('should exist', () => {
|
||||
expect(fs.existsSync(iconPath)).toBe(true);
|
||||
});
|
||||
it('should exist', () => {
|
||||
expect(fs.existsSync(iconPath)).toBe(true);
|
||||
});
|
||||
|
||||
it('should have correct dimensions (512x512)', async () => {
|
||||
const metadata = await sharp(iconPath).metadata();
|
||||
expect(metadata.width).toBe(512);
|
||||
expect(metadata.height).toBe(512);
|
||||
});
|
||||
it('should have correct dimensions (512x512)', async () => {
|
||||
const metadata = await sharp(iconPath).metadata();
|
||||
expect(metadata.width).toBe(512);
|
||||
expect(metadata.height).toBe(512);
|
||||
});
|
||||
|
||||
it('should be PNG format', async () => {
|
||||
const metadata = await sharp(iconPath).metadata();
|
||||
expect(metadata.format).toBe('png');
|
||||
});
|
||||
it('should be PNG format', async () => {
|
||||
const metadata = await sharp(iconPath).metadata();
|
||||
expect(metadata.format).toBe('png');
|
||||
});
|
||||
|
||||
it('should have valid RGBA encoding', async () => {
|
||||
const metadata = await sharp(iconPath).metadata();
|
||||
expect(metadata.channels).toBeGreaterThanOrEqual(3); // At least RGB
|
||||
});
|
||||
it('should have valid RGBA encoding', async () => {
|
||||
const metadata = await sharp(iconPath).metadata();
|
||||
expect(metadata.channels).toBeGreaterThanOrEqual(3); // At least RGB
|
||||
});
|
||||
|
||||
it('should be less than 200KB', () => {
|
||||
const stats = fs.statSync(iconPath);
|
||||
const sizeInKB = stats.size / 1024;
|
||||
// Note: With current icon-source.png (672KB RGB), achieving both <200KB AND RGBA
|
||||
// is not possible with lossless PNG compression. Trade-off: prioritize file size for web performance
|
||||
expect(sizeInKB).toBeLessThan(300); // Relaxed from 200KB due to source image constraints
|
||||
});
|
||||
it('should be less than 200KB', () => {
|
||||
const stats = fs.statSync(iconPath);
|
||||
const sizeInKB = stats.size / 1024;
|
||||
// Note: With current icon-source.png (672KB RGB), achieving both <200KB AND RGBA
|
||||
// is not possible with lossless PNG compression. Trade-off: prioritize file size for web performance
|
||||
expect(sizeInKB).toBeLessThan(300); // Relaxed from 200KB due to source image constraints
|
||||
});
|
||||
|
||||
it('should have transparency support (alpha channel)', async () => {
|
||||
const metadata = await sharp(iconPath).metadata();
|
||||
// Note: Source image is RGB without alpha. When using palette optimization for file size,
|
||||
// Sharp removes unused alpha channel. This is acceptable as transparency is not needed for this icon.
|
||||
expect(metadata.channels).toBeGreaterThanOrEqual(3); // Accept RGB or RGBA
|
||||
});
|
||||
it('should have transparency support (alpha channel)', async () => {
|
||||
const metadata = await sharp(iconPath).metadata();
|
||||
// Note: Source image is RGB without alpha. When using palette optimization for file size,
|
||||
// Sharp removes unused alpha channel. This is acceptable as transparency is not needed for this icon.
|
||||
expect(metadata.channels).toBeGreaterThanOrEqual(3); // Accept RGB or RGBA
|
||||
});
|
||||
|
||||
it('should not be corrupted', async () => {
|
||||
// Try to read the image - will throw if corrupted
|
||||
await expect(sharp(iconPath).metadata()).resolves.toBeDefined();
|
||||
});
|
||||
it('should not be corrupted', async () => {
|
||||
// Try to read the image - will throw if corrupted
|
||||
await expect(sharp(iconPath).metadata()).resolves.toBeDefined();
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user