Source code
Revision control
Copy as Markdown
Other Tools
# bmpsuite "questionable" tests
# See ../README.mozilla for details.
# BMP: bihsize=40, 127 x 64, bpp=1, compression=0, colors=1
# "1 bit/pixel paletted image, with only one color in the palette. The
# documentation says that 1-bpp images have a palette size of 2 (not 'up to
# 2'), but it would be silly for a viewer not to support a size of 1."
# [We accept it. So does Chromium.]
fuzzy(0-1,0-926) == pal1p1.bmp pal1p1.png
# BMP: bihsize=64, 127 x 64, bpp=1, compression=3, colors=2
# "My attempt to make a BMP file with Huffman 1D compression. It is quite
# possibly incorrect. Even if everything else about it is correct, I have no
# way to know whether it is black/white reversed."
# [We reject it. So does Chromium.]
== wrapper.html?pal1huff.bmp about:blank
# BMP: bihsize=40, 127 x 64, bpp=2, compression=0, colors=4
# "A paletted image with 2 bits/pixel. Usually only 1, 4, and 8 are allowed,
# but 2 is legal on Windows CE."
# [We reject it. Chromium accepts it.]
== wrapper.html?pal2.bmp about:blank
# BMP: bihsize=40, 127 x 64, bpp=2, compression=0, colors=4
# "Same as pal2.bmp, but with a color palette instead of grayscale palette."
# [We reject it. Chromium accepts it.]
== wrapper.html?pal2color.bmp about:blank
# BMP: bihsize=40, 127 x 64, bpp=4, compression=2, colors=13
# "An RLE-compressed image that used 'delta' codes to skip over some pixels,
# leaving them undefined. Some viewers make undefined pixels transparent,
# others make them black, and others assign them palette color 0 (purple, in
# this case)."
# [We make the undefined pixels transparent. So does Chromium.]
== pal4rletrns.bmp pal4rletrns.png
# BMP: bihsize=40, 127 x 64, bpp=4, compression=2, colors=13
# "An RLE-compressed image that uses “delta” codes, and early EOL & EOBMP
# markers, to skip over some pixels."
== pal4rlecut.bmp pal4rlecut.png
# BMP: bihsize=40, 127 x 64, bpp=8, compression=1, colors=253
# "8-bit version of q/pal4rletrns.bmp."
# [Ditto.]
== pal8rletrns.bmp pal8rletrns.png
# BMP: bihsize=40, 127 x 64, bpp=8, compression=1, colors=253
# "8-bit version of q/pal4rlecut.bmp."
== pal8rlecut.bmp pal8rlecut.png
# BMP: bihsize=40, 127 x 64, bpp=8, compression=0, colors=252
# "A file with some unused bytes between the palette and the image. This is
# probably valid, but I’m not 100% sure."
# [We accept it. So does Chromium.]
fuzzy(0-1,0-996) == pal8offs.bmp pal8.png
# BMP: bihsize=40, 127 x 64, bpp=8, compression=0, colors=300
# "An 8-bit image with 300 palette colors. This may be invalid, because the
# documentation could be interpreted to imply that 8-bit images aren’t allowed
# to have more than 256 colors."
# [We accept it. So does Chromium.]
fuzzy(0-1,0-996) == pal8oversizepal.bmp pal8.png
# BMP: bihsize=12, 127 x 64, bpp=8, compression=0, colors=0
# # "Some OS/2 BMP specifications say that the size field in the file header
# should be set to the aggregate size of the file header and infoheader,
# instead of the total file size. For OS/2v1, that means it will always be 26.
# BMP decoders usually ignore this field, so it shouldn’t cause a problem."
fuzzy(0-1,0-996) == pal8os2-sz.bmp pal8.png
# BMP: bihsize=12, 127 x 64, bpp=8, compression=0, colors=0
# "Some OS/2 BMP specifications define the fields at offsets 6 and 8 to be a
# “hotspot” (for cursor graphics). Though the fields are not used in BMP files,
# they are sometimes, as in this file, set to nonzero values. This should cause
# no problems, except that it could prevent some programs from detecting this
# file as a BMP file."
fuzzy(0-1,0-996) == pal8os2-hs.bmp pal8.png
# BMP: bihsize=12, 127 x 64, bpp=8, compression=0, colors=0
# "An OS/2v1 with a less-than-full-sized palette. Probably not valid, but such
# files have been seen in the wild."
# [We reject it. Chromium accepts it.]
fuzzy(0-245,0-8128) == wrapper.html?pal8os2sp.bmp about:blank
# BMP: bihsize=64, 127 x 64, bpp=8, compression=0, colors=252
# "My attempt to make an OS/2v2 bitmap."
# [We accept it. So does Chromium.]
fuzzy(0-1,0-996) == pal8os2v2.bmp pal8.png
# BMP: bihsize=16, 127 x 64, bpp=8, compression=0, colors=0
# "An OS/2v2 bitmap whose header has only 16 bytes, instead of the full 64."
# [We accept it. So does Chromium.]
fuzzy(0-1,0-996) == pal8os2v2-16.bmp pal8.png
# BMP: bihsize=64, 127 x 64, bpp=8, compression=0, colors=252
# "An OS/2v2 bitmap. Like q/pal8os2-sz.bmp, the size field is set to the size
# of the headers (78), instead of the size of the file."
fuzzy(0-1,0-996) == pal8os2v2-sz.bmp pal8.png
# BMP: bihsize=40, 127 x 64, bpp=8, compression=0, colors=252
# "An OS/2v2 bitmap, with a 40-byte header. Like q/pal8os2-sz.bmp, the size
# field is set to the size of the headers (54), instead of the size of the
# file. Except for that, this file cannot be distinguished from a Windows
# BMPv3 file."
fuzzy(0-1,0-996) == pal8os2v2-40sz.bmp pal8.png
# BMP: bihsize=40, 127 x 64, bpp=16, compression=0, colors=0
# "Same idea as q/rgb32fakealpha.bmp. The default 16-bit color format has one
# unused bit per pixel, and in this image some of the unused bits are set to 1.
# It’s possible that some viewers will interpret this image as having
# transparency."
fuzzy(0-1,0-1296) == rgb16faketrns.bmp rgb16.png
# BMP: bihsize=40, 127 x 64, bpp=16, compression=3, colors=0
# "An unusual and silly 16-bit image, with 2 red bits, 3 green bits, and 1 blue
# bit. Most viewers do support this image, but the colors may be darkened with
# a yellow-green shadow. That’s because they’re doing simple bit-shifting
# (possibly including one round of bit replication), instead of proper
# scaling."
== rgb16-231.bmp rgb16-231.png
# BMP: bihsize=40, 127 x 64, bpp=16, compression=3, colors=0
# "Similar to q/rgb16-231.bmp, with 3 red bits, 10 green bits, and 3 blue
# bits."
fuzzy(0-1,0-689) == rgb16-3103.bmp rgb16-3103.png
# BMP: bihsize=124, 127 x 64, bpp=16, compression=3, colors=0
# "A 16-bit image with an alpha channel. There are 4 bits for each color
# channel, and 4 bits for the alpha channel. It’s not clear if this is valid,
# but I can’t find anything that suggests it isn’t."
== rgba16-4444.bmp rgba16-4444.png
# BMP: bihsize=124, 127 x 64, bpp=16, compression=3, colors=0
# "Similar to q/rgba16-4444.bmp, with 5 red bits, 5 green bits, 5 blue bits,
# and a 1-bit alpha channel."
fuzzy(0-1,0-2203) == rgba16-5551.bmp rgba16-5551.png
# BMP: bihsize=124, 127 x 64, bpp=16, compression=3, colors=0
# "Similar to q/rgba16-4444.bmp, with 1 red bit, 9 green bits, 2 blue bits,
# and 4 bits for the alpha channel."
== rgba16-1924.bmp rgba16-1924.png
# BMP: bihsize=40, 127 x 64, bpp=24, compression=0, colors=300
# "A 24-bit image, with a palette containing 300 colors. The fact that the
# palette has more than 256 colors may cause some viewers to complain, but the
# documentation does not mention a size limit."
# [We accept it. So does Chromium.]
== rgb24largepal.bmp rgb24.png
# BMP: bihsize=124, 127 x 64, bpp=24, compression=0, colors=0
# "My attempt to make a BMP file with an embedded color profile."
fuzzy(1-1,28-73) == rgb24prof.bmp rgb24.png
# BMP: bihsize=124, 127 x 64, bpp=24, compression=0, colors=0
# "This image tries to test whether color profiles are fully supported. It has
# the red and green channels swapped, and an embedded color profile that tries
# to swap them back. Support for this is uncommon."
# [The image is significantly closer to the desired output than without color
fuzzy(10-10,6590-6597) == rgb24prof2.bmp rgb24.png
# BMP: bihsize=124, 127 x 64, bpp=24, compression=0, colors=0
# "My attempt to make a BMP file with a linked color profile."
# [We accept it, though we don't do anything with the color profile. Chromium
# also handles it.]
== rgb24lprof.bmp rgb24.png
# BMP: bihsize=124, 127 x 64, bpp=0, compression=4, colors=0
# BMP: bihsize=124, 127 x 64, bpp=0, compression=5, colors=0
# "My attempt to make BMP files with embedded JPEG and PNG images. These are
# not likely to be supported by much of anything (they’re intended for
# printers)."
# [We reject them. Chromium accepts them.]
== wrapper.html?rgb24jpeg.bmp about:blank
== wrapper.html?rgb24png.bmp about:blank
# BMP: bihsize=64, 127 x 64, bpp=24, compression=4, colors=0
# "An OS/2v2 bitmap with RLE24 compression. This image uses a limited number
# of colors, just to make it more compressible."
# [We reject it. Chromium accepts it.]
== wrapper.html?rgb24rle24.bmp about:blank
# BMP: bihsize=52, 127 x 64, bpp=32, compression=3, colors=0
# "Similar to g/rgb32bf.bmp, but with a 52-byte “BITMAPV2INFOHEADER”. This is
# an uncommon version of BMP, and I can’t confirm that this file is correct."
# [We reject it. Chromium accepts it.]
== wrapper.html?rgb32h52.bmp about:blank
# BMP: bihsize=124, 127 x 64, bpp=32, compression=3, colors=0
# "Color channels are the same size and order as rgb32bfdef.bmp, but they use
# the highest available bits, instead of the lowest (or vice versa, depending
# on your byte-order perspective)."
== rgb32-xbgr.bmp rgb24.png
# BMP: bihsize=40, 127 x 64, bpp=32, compression=0, colors=0
# "Same as g/rgb32.bmp, except that the unused bits are set to something other
# than 0. If the image becomes transparent toward the bottom, it probably means
# the viewer uses heuristics to guess whether the undefined data represents
# transparency."
# [We don't apply transparency here. Chromium does the same.]
== rgb32fakealpha.bmp rgb24.png
# BMP: bihsize=40, 127 x 64, bpp=32, compression=3, colors=0
# "A 32 bits/pixel image, with all 32 bits used: 11 each for red and green, and
# 10 for blue. As far as I know, this is perfectly valid, but it is unusual."
fuzzy(0-1,0-1408) == rgb32-111110.bmp rgb24.png
# BMP: bihsize=40, 127 x 64, bpp=32, compression=3, colors=0
# "A 32 bits/pixel image, with 7 bits for red, 18 for green, and 7 for blue."
fuzzy(0-1,0-753) == rgb32-7187.bmp rgb32-7187.png
# BMP: bihsize=124, 127 x 64, bpp=32, compression=3, colors=0
# "A BMP with an alpha channel. Transparency is barely documented, so it’s
# possible that this file is not correctly formed. The color channels are in an
# unusual order, to prevent viewers from passing this test by making a lucky
# guess."
== rgba32-1.bmp rgba32.png
# BMP: bihsize=124, 127 x 64, bpp=32, compression=3, colors=0
# "Same as rgba32-1.bmp, but with the color channels in an unusual order, to
# prevent viewers from passing this test by making a lucky guess."
== rgba32-2.bmp rgba32.png
# BMP: bihsize=124, 127 x 64, bpp=32, compression=3, colors=0
# "A 32 bits/pixel image, with 10 bits for red, 10 for green, 10 for blue, and
# 2 for alpha."
fuzzy(0-1,0-1296) == rgba32-1010102.bmp rgba32-1010102.png
# BMP: bihsize=124, 127 x 64, bpp=32, compression=3, colors=0
# "A 32 bits/pixel image, with 8 bits for red, 12 for green, 8 for blue, and 4
# for alpha."
fuzzy(0-1,0-753) == rgba32-81284.bmp rgba32-81284.png
# BMP: bihsize=124, 127 x 64, bpp=32, compression=3, colors=0
# "A 32 bits/pixel image, with 6 bits for red, 17 for green, 5 for blue, and 4
# for alpha."
fuzzy(0-1,0-1554) == rgba32-61754.bmp rgba32-61754.png
# BMP: bihsize=40, 127 x 64, bpp=32, compression=6, colors=0
# "An image of type BI_ALPHABITFIELDS. Supposedly, this was used on Windows CE.
# I don’t know whether it is constructed correctly."
# [We reject it. Chromium accepts it.]
== wrapper.html?rgba32abf.bmp about:blank
# BMP: bihsize=56, 127 x 64, bpp=32, compression=3, colors=0
# "Similar to q/rgba32.bmp, but with a 56-byte “BITMAPV3INFOHEADER”. This is an
# uncommon version of BMP, and I can’t confirm that this file is correct."
# [We reject it. Chromium accepts it.]
== wrapper.html?rgba32h56.bmp about:blank