[Spice-devel] [PATCH vd_agent_linux v2 5/7] Add a test to test file creation

Victor Toso victortoso at redhat.com
Wed Jan 16 09:59:22 UTC 2019


Hi,

On Wed, Jan 16, 2019 at 09:49:22AM +0000, Frediano Ziglio wrote:
> Signed-off-by: Frediano Ziglio <fziglio at redhat.com>
Acked-by: Victor Toso <victortoso at redhat.com>
> ---
> Changes since v1:
> - move file to a new tests/ directory;
> - add missing .gitignore changes;
> - improve test to catch errors in open() other than EEXISTS.
> ---
>  .gitignore              | 17 +++++----
>  Makefile.am             | 22 ++++++++++++
>  tests/test-file-xfers.c | 77 +++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 107 insertions(+), 9 deletions(-)
>  create mode 100644 tests/test-file-xfers.c
> 
> diff --git a/.gitignore b/.gitignore
> index ae47a90..76d4081 100644
> --- a/.gitignore
> +++ b/.gitignore
> @@ -1,19 +1,16 @@
>  *~
> +*.o
> +.deps
> +.dirstamp
>  data/spice-vdagent*.1
>  src/config.h
>  src/config.h.in
>  src/spice-vdagent
>  src/spice-vdagentd
>  src/stamp-h1
> -src/*.o
> -src/.deps
> -src/.dirstamp
> -src/vdagent/*.o
> -src/vdagent/.deps
> -src/vdagent/.dirstamp
> -src/vdagentd/*.o
> -src/vdagentd/.deps
> -src/vdagentd/.dirstamp
> +tests/test-*.log
> +tests/test-*.trs
> +tests/test-file-xfers
>  config.log
>  config.status
>  aclocal.m4
> @@ -25,3 +22,5 @@ install-sh
>  Makefile.in
>  Makefile
>  missing
> +test-driver
> +test-suite.log
> diff --git a/Makefile.am b/Makefile.am
> index 3e405bc..97b8bf0 100644
> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -3,6 +3,8 @@ NULL =
>  
>  bin_PROGRAMS = src/spice-vdagent
>  sbin_PROGRAMS = src/spice-vdagentd
> +check_PROGRAMS = tests/test-file-xfers
> +TESTS = $(check_PROGRAMS)
>  
>  common_sources =				\
>  	src/udscs.c				\
> @@ -44,6 +46,26 @@ src_spice_vdagent_SOURCES =			\
>  	src/vdagent/vdagent.c			\
>  	$(NULL)
>  
> +tests_test_file_xfers_CFLAGS =			\
> +	$(SPICE_CFLAGS)				\
> +	$(GLIB2_CFLAGS)				\
> +	-I$(srcdir)/src				\
> +	-I$(srcdir)/src/vdagent			\
> +	-DUDSCS_NO_SERVER			\
> +	$(NULL)
> +
> +tests_test_file_xfers_LDADD =			\
> +	$(SPICE_LIBS)				\
> +	$(GLIB2_LIBS)				\
> +	$(NULL)
> +
> +tests_test_file_xfers_SOURCES =			\
> +	$(common_sources)			\
> +	src/vdagent/file-xfers.c		\
> +	src/vdagent/file-xfers.h		\
> +	tests/test-file-xfers.c			\
> +	$(NULL)
> +
>  src_spice_vdagentd_CFLAGS =			\
>  	$(DBUS_CFLAGS)				\
>  	$(LIBSYSTEMD_DAEMON_CFLAGS)		\
> diff --git a/tests/test-file-xfers.c b/tests/test-file-xfers.c
> new file mode 100644
> index 0000000..e40a89b
> --- /dev/null
> +++ b/tests/test-file-xfers.c
> @@ -0,0 +1,77 @@
> +/*  test-file-xfers.c  - test file transfer
> +
> +    Copyright 2019 Red Hat, Inc.
> +
> +    This program is free software: you can redistribute it and/or modify
> +    it under the terms of the GNU General Public License as published by
> +    the Free Software Foundation, either version 3 of the License, or
> +    (at your option) any later version.
> +
> +    This program is distributed in the hope that it will be useful,
> +    but WITHOUT ANY WARRANTY; without even the implied warranty of
> +    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> +    GNU General Public License for more details.
> +
> +    You should have received a copy of the GNU General Public License
> +    along with this program.  If not, see <http://www.gnu.org/licenses/>.
> +*/
> +#include <config.h>
> +
> +#undef NDEBUG
> +#include <assert.h>
> +#include <stdio.h>
> +#include <stdlib.h>
> +#include <string.h>
> +#include <unistd.h>
> +#include <glib.h>
> +
> +#include <spice/vd_agent.h>
> +
> +#include "file-xfers.h"
> +
> +static void test_file(const char *file_name, const char *out)
> +{
> +    char *fn = g_strdup(file_name);
> +    int fd = vdagent_file_xfers_create_file("./test-dir", &fn);
> +    if (out) {
> +        g_assert_cmpint(fd, !=, -1);
> +        g_assert_cmpstr(fn, ==, out);
> +        close(fd);
> +        g_assert_cmpint(access(out, W_OK), ==, 0);
> +    } else {
> +        g_assert_cmpint(fd, ==, -1);
> +    }
> +    g_free(fn);
> +}
> +
> +int main(int argc, char *argv[])
> +{
> +    assert(system("rm -rf test-dir && mkdir test-dir") == 0);
> +
> +    // create a file
> +    test_file("test.txt", "./test-dir/test.txt");
> +
> +    // create a file with an existing name
> +    for (int i = 1; i < 64; ++i) {
> +        char out_name[64];
> +        sprintf(out_name, "./test-dir/test (%d).txt", i);
> +        test_file("test.txt", out_name);
> +    }
> +
> +    // check too much files with the same name
> +    test_file("test.txt", NULL);
> +
> +    // create a file in a subdirectory not existing
> +    test_file("subdir/test.txt", "./test-dir/subdir/test.txt");
> +
> +    // create a file in a directory with no permissions
> +    assert(system("chmod 555 test-dir/subdir") == 0);
> +    test_file("subdir/test2.txt", NULL);
> +
> +    // try to create a file with a path where there's a file (should fail)
> +    test_file("test.txt/out", NULL);
> +
> +    assert(system("chmod 755 test-dir/subdir && rm -rf test-dir") == 0);
> +
> +    return 0;
> +}
> -- 
> 2.20.1
> 
> _______________________________________________
> Spice-devel mailing list
> Spice-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/spice-devel
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: not available
URL: <https://lists.freedesktop.org/archives/spice-devel/attachments/20190116/0dafc454/attachment-0001.sig>


More information about the Spice-devel mailing list