From 4a257d90dbca22716f018b14212af7d725e95ae3 Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 20:06:36 +0300 Subject: [PATCH 01/10] Alloc cross-platform tests --- configure.ac | 2 -- 1 file changed, 2 deletions(-) diff --git a/configure.ac b/configure.ac index 6e082a25..09070073 100644 --- a/configure.ac +++ b/configure.ac @@ -151,8 +151,6 @@ AS_IF([test "$with_libc" = yes], [with_libc=yes], [with_libc # Test args # ############# -AS_IF([test "$enable_tests" = yes -a "$host_cpu" != "$build_cpu" ], AC_MSG_ERROR([can not build cross-platform tests])) -AS_IF([test "$enable_tests_python" = yes -a "$host_cpu" != "$build_cpu" ], AC_MSG_ERROR([can not build cross-platform tests])) AS_IF([test "$enable_tests" = yes -a "$enable_freestanding" = yes], AC_MSG_ERROR([can not build freestanding tests])) AS_IF([test "$enable_tests_python" = yes -a "$enable_freestanding" = yes], AC_MSG_ERROR([can not build freestanding tests])) AS_IF([test "$enable_tests" = yes -a "$with_libc" = yes], AC_MSG_ERROR([can not use package `libc' with tests])) From c613b552e4af67f39485e0b36ac842cf00223317 Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 20:11:46 +0300 Subject: [PATCH 02/10] Test i386 --- .github/workflows/main.yml | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 126e8abb..04e8d784 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -29,6 +29,32 @@ jobs: - name: install run: sudo make install + cross: + runs-on: ubuntu-latest + strategy: + matrix: + cross: + - host: 'i386-unknown-elf' + apt: 'crossbuild-essential-i386' + ar: 'i686-linux-gnu-ar' + cc: 'i686-linux-gnu-gcc' + ld: 'i686-linux-gnu-ld' + ranlib: 'i686-linux-gnu-ranlib' + steps: + - uses: actions/checkout@v2 + - name: dependencies + run: sudo apt-get --yes install ${{matrix.cross.apt}} + - name: autogen + run: ./autogen.sh + - name: configure + run: ./configure --enable-tests --enable-tests-python AR='${{matrix.cross.ar}}' CC='${{matrix.cross.cc}}' LD='${{matrix.cross.ld}}' RANLIB='${{matrix.cross.ranlib}}' + - name: make + run: make + - name: check + run: make check || (./test-suite-log && false) + - name: install + run: sudo make install + cond: runs-on: ubuntu-latest strategy: From 8a246bd2db3beb537fb99c6e3b7ca656fb2265ac Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 20:15:44 +0300 Subject: [PATCH 03/10] Less verbose CI config --- .github/workflows/main.yml | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 04e8d784..e15e1f4c 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -36,10 +36,7 @@ jobs: cross: - host: 'i386-unknown-elf' apt: 'crossbuild-essential-i386' - ar: 'i686-linux-gnu-ar' - cc: 'i686-linux-gnu-gcc' - ld: 'i686-linux-gnu-ld' - ranlib: 'i686-linux-gnu-ranlib' + cprefix: 'i686-linux-gnu-' steps: - uses: actions/checkout@v2 - name: dependencies @@ -47,7 +44,7 @@ jobs: - name: autogen run: ./autogen.sh - name: configure - run: ./configure --enable-tests --enable-tests-python AR='${{matrix.cross.ar}}' CC='${{matrix.cross.cc}}' LD='${{matrix.cross.ld}}' RANLIB='${{matrix.cross.ranlib}}' + run: ./configure --enable-tests --enable-tests-python AR='${{matrix.cross.cprefix}}ar' CC='${{matrix.cross.cprefix}}gcc' LD='${{matrix.cross.cprefix}}ld' RANLIB='${{matrix.cross.cprefix}}ranlib' - name: make run: make - name: check From 3cdbe7616f48ecd2ef8b73073528cff855e69179 Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 20:16:29 +0300 Subject: [PATCH 04/10] Specify host in CI --- .github/workflows/main.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index e15e1f4c..5e1c9075 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -44,7 +44,7 @@ jobs: - name: autogen run: ./autogen.sh - name: configure - run: ./configure --enable-tests --enable-tests-python AR='${{matrix.cross.cprefix}}ar' CC='${{matrix.cross.cprefix}}gcc' LD='${{matrix.cross.cprefix}}ld' RANLIB='${{matrix.cross.cprefix}}ranlib' + run: ./configure --host='${{matrix.cross.host}}' --enable-tests --enable-tests-python AR='${{matrix.cross.cprefix}}ar' CC='${{matrix.cross.cprefix}}gcc' LD='${{matrix.cross.cprefix}}ld' RANLIB='${{matrix.cross.cprefix}}ranlib' - name: make run: make - name: check From e17a21d61bb6468fc51996480c809d690d98b44d Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 20:30:59 +0300 Subject: [PATCH 05/10] Add "tests/test_printf" --- .gitignore | 1 + tests/Makefile.am | 12 ++++++++++++ tests/test_printf_reg.c | 34 ++++++++++++++++++++++++++++++++++ 3 files changed, 47 insertions(+) create mode 100644 tests/test_printf_reg.c diff --git a/.gitignore b/.gitignore index fa56d74d..8f453765 100644 --- a/.gitignore +++ b/.gitignore @@ -147,4 +147,5 @@ /tests/test_printf_fmt_gen.c /tests/test_printf_gen /tests/test_printf_gen.c +/tests/test_printf_reg /tests/test_units_human diff --git a/tests/Makefile.am b/tests/Makefile.am index 6031286f..b678d571 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -335,6 +335,18 @@ CLEANFILES += test_printf_gen.c test_printf_gen.c: printf_gen.py printf_gen.jinja $(top_srcdir)/common/printf.yml $(top_srcdir)/common/printf_orig.yml python3 printf_gen.py +################### +# test_printf_reg # +################### + +if WITH_PRINTF +TESTS += test_printf_reg +test_printf_reg_LDADD = $(top_builddir)/libkernaux.la +test_printf_reg_SOURCES = \ + main.c \ + test_printf_reg.c +endif + #################### # test_units_human # #################### diff --git a/tests/test_printf_reg.c b/tests/test_printf_reg.c new file mode 100644 index 00000000..75f8ec5a --- /dev/null +++ b/tests/test_printf_reg.c @@ -0,0 +1,34 @@ +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include + +#include +#include +#include + +void test_main() +{ + char buffer[1000]; + + // Sanity check + { + memset(buffer, 0xff, sizeof(buffer)); + const int result = + kernaux_snprintf(buffer, sizeof(buffer), "%s", "Hello, World!"); + fprintf(stderr, "%d:%s\n", result, buffer); + assert(result == 13); + assert(strcmp(buffer, "Hello, World!") == 0); + } + + // i386 requires "(long long)0" instead of just "0" + { + memset(buffer, 0xff, sizeof(buffer)); + const int result = + kernaux_snprintf(buffer, sizeof(buffer), "%#.0llx", (long long)0); + fprintf(stderr, "%d:%s\n", result, buffer); + assert(result == 0); + assert(strcmp(buffer, "") == 0); + } +} From 599759933827f39c3ae5b1d9561c0a9fac31c40f Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 20:59:08 +0300 Subject: [PATCH 06/10] Fix generation --- tests/printf_gen.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/tests/printf_gen.py b/tests/printf_gen.py index 343e7924..bc322a1f 100644 --- a/tests/printf_gen.py +++ b/tests/printf_gen.py @@ -65,7 +65,12 @@ def values(args): if type(arg[1]) is str: values += ', ' + escape_str(arg[1]) elif type(arg[1]) is list: - values += ', ' + escape_char(arg[1][0]) + if len(arg[1]) == 1: + values += ', ' + escape_char(arg[1][0]) + elif arg[1][0] == 'long long': + values += ', (long long)' + str(arg[1][1]) + else: + raise RuntimeError('unknown format: ' + str(args)) else: values += ', ' + str(arg[1]) From 5686dbcb3941048b5b032580d9164ae0b7b2e6d6 Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 21:00:09 +0300 Subject: [PATCH 07/10] Fix tests --- common/printf_orig.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/common/printf_orig.yml b/common/printf_orig.yml index 31513d65..5a4d8282 100644 --- a/common/printf_orig.yml +++ b/common/printf_orig.yml @@ -196,7 +196,7 @@ - result: '0' args: [['%#.1x', 0]] - result: '' - args: [['%#.0llx', 0]] + args: [['%#.0llx', ['long long', 0]]] - result: '0x0000614e' args: [['%#.8x', 0x614e]] - result: '0b110' From 3badf0908c73b30fe7b0759ab95a5870aa03216b Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 21:02:11 +0300 Subject: [PATCH 08/10] Fix Ruby tests --- bindings/ruby/spec/lib/kernaux/printf/sprintf_spec.rb | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/bindings/ruby/spec/lib/kernaux/printf/sprintf_spec.rb b/bindings/ruby/spec/lib/kernaux/printf/sprintf_spec.rb index 7010b390..ba11072a 100644 --- a/bindings/ruby/spec/lib/kernaux/printf/sprintf_spec.rb +++ b/bindings/ruby/spec/lib/kernaux/printf/sprintf_spec.rb @@ -36,7 +36,13 @@ else arg.map do |item| if item.is_a? Array - item[0] + if item.length == 1 + item[0] + elsif item[0] == 'long long' + item[1] + else + raise "Unknown format: #{args.inspect}" + end else item end From cf2a98ba4ed394c0b2dc0ec2aae486fcaa920a1c Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 21:03:49 +0300 Subject: [PATCH 09/10] Fix mruby tests --- bindings/mruby/test/printf.rb | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/bindings/mruby/test/printf.rb b/bindings/mruby/test/printf.rb index 5cffaab4..922567ea 100644 --- a/bindings/mruby/test/printf.rb +++ b/bindings/mruby/test/printf.rb @@ -56,7 +56,13 @@ else arg.map do |item| if item.is_a? Array - item[0] + if item.length == 1 + item[0] + elsif item[0] == 'long long' + item[1] + else + raise "Unknown format: #{args.inspect}" + end else item end From c5f7bc750b5ba03277a6e331aaa6d96316ee05be Mon Sep 17 00:00:00 2001 From: Alex Kotov Date: Tue, 21 Jun 2022 21:09:06 +0300 Subject: [PATCH 10/10] mruby: Disable cop Metrics/BlockNesting for printf test --- bindings/mruby/.rubocop.yml | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/bindings/mruby/.rubocop.yml b/bindings/mruby/.rubocop.yml index 1b268e56..084bd23b 100644 --- a/bindings/mruby/.rubocop.yml +++ b/bindings/mruby/.rubocop.yml @@ -25,6 +25,10 @@ Metrics/BlockLength: - 'Rakefile' - 'test/**/*.rb' +Metrics/BlockNesting: + Exclude: + - 'test/printf.rb' + Security/Eval: Exclude: - 'test/**/*.rb'