1#!/bin/sh 2# 3# Copyright 1999-2021 ImageMagick Studio LLC, a non-profit organization 4# dedicated to making software imaging solutions freely available. 5# 6# You may not use this file except in compliance with the License. You may 7# obtain a copy of the License at 8# 9# https://imagemagick.org/script/license.php 10# 11# Unless required by applicable law or agreed to in writing, software 12# distributed under the License is distributed on an "AS IS" BASIS, 13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14# See the License for the specific language governing permissions and 15# limitations under the License. 16# 17. ./common.shi 18. ${srcdir}/tests/common.shi 19 20depth=`eval ${MAGICK} xc:none -format '%[fx:QuantumRange]' info:-` 21if [ "X$depth" = "X255" ]; then 22 echo "1..1" 23 echo "ok" 24 exit 0 25fi 26echo "1..19" 27 28# how to generate a one pixel (average rose) color and output its values 29in="rose: -scale 1x1" # a one pixel image of the average color. 30out="-format '%[fx:int(255*r+.5)],%[fx:int(255*g+.5)],%[fx:int(255*b+.5)]' info:-" 31 32# ---------------- 33 34# Colors to compare results to. 35error=false 36average=`eval ${MAGICK} "$in" -noop "$out"` 37too_dark=`eval ${MAGICK} "$in" -colorspace RGB "$out"` 38too_light=`eval ${MAGICK} "$in" -set colorspace RGB -colorspace sRGB "$out"` 39format='%-30s%s\n' # results formating 40format2='%-30s%-14s%s\n' 41 42printf "$format2" "Average \"rose:\" Color" "$average" "sRGB(rose)" 43printf "$format2" "Too Dark Color" "$too_dark" "sRGB(rose)->RGB result" 44printf "$format2" "Too Light Color" "$too_light" "RGB(rose)->sRGB result" 45echo '' 46 47# 48# Sanity checks 49# 50# NOTE: as a extra validation on sanity checks below... 51# eval ${MAGICK} "$in" -gamma .454545 "$out" 52# produces a value of 74,25,20 which is close to 73,26,21 below. 53# eval ${MAGICK} "$in" -gamma 2.2 "$out" 54# produces a value of 198,158,151 whcih is close to 199,160,152 below. 55# 56# Actual values used below come from IM v6.5.4-7 colorspace conversions 57# 58error=false 59if [ "X$average" != "X146,89,80" ]; then 60 echo "Sanity Failure: Average expected to be 145,89,80 - ABORTING" 61 error=true 62fi 63if [ "X$too_dark" != "X73,26,21" ]; then 64 echo "Sanity Failure: Too Dark expected to be 73,26,21 - ABORTING" 65 error=true 66fi 67if [ "X$too_light" != "X199,160,152" ]; then 68 echo "Sanity Failure: Too Light expected to be 199,160,152 - ABORTING" 69 error=true 70fi 71$error && exit 1 72 73test_color() { 74 test="sRGB" 75 cs=''; 76 for i in "$@"; do 77 test="${test}->$i" # format of the test being performed 78 cs="$cs -colorspace $i" # colorspace operations to perform test 79 done 80 color=`eval ${MAGICK} "$in" $cs "$out"` 81 82 if [ "X$color" = "X$average" ]; then 83 return 0 84 fi 85 # Its failed the round-trip test, now report how it failed! 86 error=true 87 if [ "X$color" = "X$too_light" ]; then 88 return 1 89 fi 90 if [ "X$color" = "X$too_dark" ]; then 91 return 1 92 fi 93 return 1 94} 95 96# ---------------- 97 98test_color RGB sRGB && echo "ok" || echo "not ok" 99 100test_color XYZ sRGB && echo "ok" || echo "not ok" 101test_color XYZ RGB sRGB && echo "ok" || echo "not ok" 102test_color RGB XYZ sRGB && echo "ok" || echo "not ok" 103 104test_color LAB sRGB && echo "ok" || echo "not ok" 105test_color XYZ LAB sRGB && echo "ok" || echo "not ok" 106test_color LAB XYZ sRGB && echo "ok" || echo "not ok" 107test_color RGB LAB sRGB && echo "ok" || echo "not ok" 108test_color LAB RGB sRGB && echo "ok" || echo "not ok" 109 110test_color CMY sRGB && echo "ok" || echo "not ok" 111test_color CMYK sRGB && echo "ok" || echo "not ok" 112test_color HSL sRGB && echo "ok" || echo "not ok" 113test_color HSB sRGB && echo "ok" || echo "not ok" 114test_color HWB sRGB && echo "ok" || echo "not ok" 115test_color Log sRGB && echo "ok" || echo "not ok" 116test_color YIQ sRGB && echo "ok" || echo "not ok" 117test_color YUV sRGB && echo "ok" || echo "not ok" 118test_color YCbCr sRGB && echo "ok" || echo "not ok" 119test_color OHTA sRGB && echo "ok" || echo "not ok" 120: 121