2020-05-05 22:51:04 +01:00
/*
libzint - the open source barcode library
2021-06-10 11:15:39 +01:00
Copyright ( C ) 2020 - 2021 Robin Stuart < rstuart114 @ gmail . com >
2020-05-05 22:51:04 +01:00
Redistribution and use in source and binary forms , with or without
modification , are permitted provided that the following conditions
are met :
1. Redistributions of source code must retain the above copyright
notice , this list of conditions and the following disclaimer .
2. Redistributions in binary form must reproduce the above copyright
notice , this list of conditions and the following disclaimer in the
documentation and / or other materials provided with the distribution .
3. Neither the name of the project nor the names of its contributors
may be used to endorse or promote products derived from this software
without specific prior written permission .
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS " AS IS " AND
ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT , INDIRECT , INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL
DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS
OR SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS INTERRUPTION )
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT
LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY
OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF
SUCH DAMAGE .
*/
/* vim: set ts=4 sw=4 et : */
# include "testcommon.h"
2020-08-12 22:16:11 +01:00
# include <sys/stat.h>
2020-05-05 22:51:04 +01:00
2020-08-12 22:16:11 +01:00
static void test_print ( int index , int generate , int debug ) {
struct item {
int symbology ;
2020-09-30 12:19:12 +01:00
int input_mode ;
2021-07-26 15:29:05 +01:00
int border_width ;
2020-09-30 12:19:12 +01:00
int output_options ;
2020-08-12 22:16:11 +01:00
int whitespace_width ;
2021-07-26 15:29:05 +01:00
int whitespace_height ;
2020-08-12 22:16:11 +01:00
int option_1 ;
int option_2 ;
char * fgcolour ;
char * bgcolour ;
2020-10-03 22:51:08 +01:00
int rotate_angle ;
2020-11-27 12:54:44 +00:00
char * data ;
char * expected_file ;
char * comment ;
2020-08-12 22:16:11 +01:00
} ;
struct item data [ ] = {
2021-07-26 15:29:05 +01:00
/* 0*/ { BARCODE_CODE128 , UNICODE_MODE , - 1 , BOLD_TEXT , - 1 , - 1 , - 1 , - 1 , " " , " " , 0 , " Égjpqy " , " code128_egrave_bold.emf " , " " } ,
/* 1*/ { BARCODE_TELEPEN , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " 147AD0 " , " FC9630 " , 0 , " 123 " , " telenum_fg_bg.emf " , " " } ,
/* 2*/ { BARCODE_ULTRA , - 1 , - 1 , - 1 , 5 , - 1 , - 1 , - 1 , " 147AD0 " , " FC9630 " , 0 , " 123 " , " ultracode_fg_bg.emf " , " " } ,
/* 3*/ { BARCODE_ULTRA , - 1 , 2 , BARCODE_BOX , 2 , 2 , - 1 , - 1 , " FF0000 " , " 0000FF " , 0 , " 123 " , " ultracode_fg_bg_box2.emf " , " " } ,
/* 4*/ { BARCODE_EANX , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " " , " " , 0 , " 9780877799306+54321 " , " ean13_5addon_ggs_5.2.2.5.2-2.emf " , " " } ,
/* 5*/ { BARCODE_EANX , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " " , " " , 0 , " 210987654321+54321 " , " ean13_5addon_#185.emf " , " #185 Byte count, font data, HeaderExtension1/2 " } ,
/* 6*/ { BARCODE_UPCA , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " " , " " , 0 , " 012345678905+24 " , " upca_2addon_ggs_5.2.6.6-5.emf " , " " } ,
/* 7*/ { BARCODE_UPCE , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " " , " " , 0 , " 0123456+12 " , " upce_2addon.emf " , " " } ,
/* 8*/ { BARCODE_UPCE , - 1 , - 1 , SMALL_TEXT | BOLD_TEXT , - 1 , - 1 , - 1 , - 1 , " " , " " , 0 , " 0123456+12 " , " upce_2addon_small_bold.emf " , " " } ,
/* 9*/ { BARCODE_ITF14 , - 1 , - 1 , BOLD_TEXT , - 1 , - 1 , - 1 , - 1 , " " , " " , 0 , " 123 " , " itf14_bold.emf " , " " } ,
/* 10*/ { BARCODE_CODE39 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " " , " " , 90 , " 123 " , " code39_rotate_90.emf " , " " } ,
/* 11*/ { BARCODE_CODE39 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " " , " " , 180 , " 123 " , " code39_rotate_180.emf " , " " } ,
/* 12*/ { BARCODE_CODE39 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " " , " " , 270 , " 123 " , " code39_rotate_270.emf " , " " } ,
/* 13*/ { BARCODE_MAXICODE , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " E0E0E0 " , " 700070 " , 0 , " THIS IS A 93 CHARACTER CODE SET A MESSAGE THAT FILLS A MODE 4, UNAPPENDED, MAXICODE SYMBOL... " , " maxicode_#185.emf " , " #185 Maxicode scaling " } ,
/* 14*/ { BARCODE_MAXICODE , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , " " , " FFFFFF00 " , 90 , " THIS IS A 93 CHARACTER CODE SET A MESSAGE THAT FILLS A MODE 4, UNAPPENDED, MAXICODE SYMBOL... " , " maxicode_rotate_90_nobg.emf " , " " } ,
2020-08-12 22:16:11 +01:00
} ;
int data_size = ARRAY_SIZE ( data ) ;
2021-06-23 15:00:49 +01:00
int i , length , ret ;
struct zint_symbol * symbol ;
2020-08-12 22:16:11 +01:00
2021-06-14 00:48:29 +01:00
const char * data_dir = " /backend/tests/data/emf " ;
const char * emf = " out.emf " ;
char expected_file [ 1024 ] ;
2020-08-12 22:16:11 +01:00
char escaped [ 1024 ] ;
int escaped_size = 1024 ;
2021-06-23 15:00:49 +01:00
int have_libreoffice = 0 ;
if ( generate ) {
have_libreoffice = testUtilHaveLibreOffice ( ) ;
}
testStart ( " test_print " ) ;
2020-08-12 22:16:11 +01:00
if ( generate ) {
2021-06-16 17:56:32 +01:00
char data_dir_path [ 1024 ] ;
assert_nonzero ( testUtilDataPath ( data_dir_path , sizeof ( data_dir_path ) , data_dir , NULL ) , " testUtilDataPath(%s) == 0 \n " , data_dir ) ;
2021-06-23 15:00:49 +01:00
if ( ! testUtilDirExists ( data_dir_path ) ) {
ret = testUtilMkDir ( data_dir_path ) ;
assert_zero ( ret , " testUtilMkDir(%s) ret %d != 0 (%d: %s) \n " , data_dir_path , ret , errno , strerror ( errno ) ) ;
2020-08-12 22:16:11 +01:00
}
}
2021-06-23 15:00:49 +01:00
for ( i = 0 ; i < data_size ; i + + ) {
2020-08-12 22:16:11 +01:00
if ( index ! = - 1 & & i ! = index ) continue ;
2021-06-23 15:00:49 +01:00
symbol = ZBarcode_Create ( ) ;
2020-08-12 22:16:11 +01:00
assert_nonnull ( symbol , " Symbol not created \n " ) ;
2021-06-23 15:00:49 +01:00
length = testUtilSetSymbol ( symbol , data [ i ] . symbology , data [ i ] . input_mode , - 1 /*eci*/ , data [ i ] . option_1 , data [ i ] . option_2 , - 1 , data [ i ] . output_options , data [ i ] . data , - 1 , debug ) ;
2021-07-26 15:29:05 +01:00
if ( data [ i ] . border_width ! = - 1 ) {
symbol - > border_width = data [ i ] . border_width ;
}
2020-08-12 22:16:11 +01:00
if ( data [ i ] . whitespace_width ! = - 1 ) {
symbol - > whitespace_width = data [ i ] . whitespace_width ;
}
2021-07-26 15:29:05 +01:00
if ( data [ i ] . whitespace_height ! = - 1 ) {
symbol - > whitespace_height = data [ i ] . whitespace_height ;
}
2020-09-30 12:19:12 +01:00
if ( * data [ i ] . fgcolour ) {
2020-08-12 22:16:11 +01:00
strcpy ( symbol - > fgcolour , data [ i ] . fgcolour ) ;
}
2020-09-30 12:19:12 +01:00
if ( * data [ i ] . bgcolour ) {
2020-08-12 22:16:11 +01:00
strcpy ( symbol - > bgcolour , data [ i ] . bgcolour ) ;
}
2020-10-03 22:51:08 +01:00
ret = ZBarcode_Encode ( symbol , ( unsigned char * ) data [ i ] . data , length ) ;
2020-08-12 22:16:11 +01:00
assert_zero ( ret , " i:%d %s ZBarcode_Encode ret %d != 0 %s \n " , i , testUtilBarcodeName ( data [ i ] . symbology ) , ret , symbol - > errtxt ) ;
strcpy ( symbol - > outfile , emf ) ;
2020-10-03 22:51:08 +01:00
ret = ZBarcode_Print ( symbol , data [ i ] . rotate_angle ) ;
2020-08-12 22:16:11 +01:00
assert_zero ( ret , " i:%d %s ZBarcode_Print %s ret %d != 0 \n " , i , testUtilBarcodeName ( data [ i ] . symbology ) , symbol - > outfile , ret ) ;
2021-06-14 00:48:29 +01:00
assert_nonzero ( testUtilDataPath ( expected_file , sizeof ( expected_file ) , data_dir , data [ i ] . expected_file ) , " i:%d testUtilDataPath == 0 \n " , i ) ;
2020-08-12 22:16:11 +01:00
if ( generate ) {
2021-07-26 15:29:05 +01:00
printf ( " /*%3d*/ { %s, %s, %d, %s, %d, %d, %d, %d, \" %s \" , \" %s \" , %d, \" %s \" , \" %s \" , \" %s \" }, \n " ,
i , testUtilBarcodeName ( data [ i ] . symbology ) , testUtilInputModeName ( data [ i ] . input_mode ) , data [ i ] . border_width ,
testUtilOutputOptionsName ( data [ i ] . output_options ) , data [ i ] . whitespace_width , data [ i ] . whitespace_height ,
2020-11-27 12:54:44 +00:00
data [ i ] . option_1 , data [ i ] . option_2 , data [ i ] . fgcolour , data [ i ] . bgcolour , data [ i ] . rotate_angle ,
testUtilEscape ( data [ i ] . data , length , escaped , escaped_size ) , data [ i ] . expected_file , data [ i ] . comment ) ;
2021-06-23 15:00:49 +01:00
ret = testUtilRename ( symbol - > outfile , expected_file ) ;
assert_zero ( ret , " i:%d testUtilRename(%s, %s) ret %d != 0 \n " , i , symbol - > outfile , expected_file , ret ) ;
2020-10-03 22:51:08 +01:00
if ( have_libreoffice ) {
2020-11-27 12:54:44 +00:00
// Note this will fail (on Ubuntu anyway) if LibreOffice Base/Calc/Impress/Writer running (i.e. anything but LibreOffice Draw)
// Doesn't seem to be a way to force Draw invocation through the command line
2021-06-14 00:48:29 +01:00
ret = testUtilVerifyLibreOffice ( expected_file , debug ) ;
assert_zero ( ret , " i:%d %s libreoffice %s ret %d != 0 \n " , i , testUtilBarcodeName ( data [ i ] . symbology ) , expected_file , ret ) ;
2020-08-12 22:16:11 +01:00
}
} else {
assert_nonzero ( testUtilExists ( symbol - > outfile ) , " i:%d testUtilExists(%s) == 0 \n " , i , symbol - > outfile ) ;
2021-06-14 00:48:29 +01:00
assert_nonzero ( testUtilExists ( expected_file ) , " i:%d testUtilExists(%s) == 0 \n " , i , expected_file ) ;
2020-08-12 22:16:11 +01:00
2021-06-14 00:48:29 +01:00
ret = testUtilCmpBins ( symbol - > outfile , expected_file ) ;
assert_zero ( ret , " i:%d %s testUtilCmpBins(%s, %s) %d != 0 \n " , i , testUtilBarcodeName ( data [ i ] . symbology ) , symbol - > outfile , expected_file , ret ) ;
2021-10-20 23:05:30 +01:00
if ( index = = - 1 ) assert_zero ( remove ( symbol - > outfile ) , " i:%d remove(%s) != 0 \n " , i , symbol - > outfile ) ;
2020-08-12 22:16:11 +01:00
}
ZBarcode_Delete ( symbol ) ;
}
testFinish ( ) ;
}
2021-07-26 15:29:05 +01:00
INTERNAL int emf_plot ( struct zint_symbol * symbol , int rotate_angle ) ;
static void test_outfile ( void ) {
int ret ;
struct zint_symbol symbol = { 0 } ;
struct zint_vector vector = { 0 } ;
testStart ( " test_outfile " ) ;
symbol . symbology = BARCODE_CODE128 ;
symbol . vector = & vector ;
strcpy ( symbol . outfile , " nosuch_dir/out.emf " ) ;
ret = emf_plot ( & symbol , 0 ) ;
assert_equal ( ret , ZINT_ERROR_FILE_ACCESS , " emf_plot ret %d != ZINT_ERROR_FILE_ACCESS (%d) (%s) \n " , ret , ZINT_ERROR_FILE_ACCESS , symbol . errtxt ) ;
symbol . output_options | = BARCODE_STDOUT ;
ret = emf_plot ( & symbol , 0 ) ;
printf ( " - ignore (EMF to stdout) \n " ) ; fflush ( stdout ) ;
assert_zero ( ret , " emf_plot ret %d != 0 (%s) \n " , ret , symbol . errtxt ) ;
symbol . vector = NULL ;
ret = emf_plot ( & symbol , 0 ) ;
assert_equal ( ret , ZINT_ERROR_INVALID_DATA , " emf_plot ret %d != ZINT_ERROR_INVALID_DATA (%d) (%s) \n " , ret , ZINT_ERROR_INVALID_DATA , symbol . errtxt ) ;
testFinish ( ) ;
}
2020-05-05 22:51:04 +01:00
int main ( int argc , char * argv [ ] ) {
testFunction funcs [ ] = { /* name, func, has_index, has_generate, has_debug */
2020-08-12 22:16:11 +01:00
{ " test_print " , test_print , 1 , 1 , 1 } ,
2021-07-26 15:29:05 +01:00
{ " test_outfile " , test_outfile , 0 , 0 , 0 } ,
2020-05-05 22:51:04 +01:00
} ;
testRun ( argc , argv , funcs , ARRAY_SIZE ( funcs ) ) ;
testReport ( ) ;
return 0 ;
}