From nobody Tue Feb 10 04:16:12 2026 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass(p=none dis=none) header.from=gmail.com ARC-Seal: i=1; a=rsa-sha256; t=1661336118; cv=none; d=zohomail.com; s=zohoarc; b=oBTpbwoWdJjBcuVbwPEzm8LhTGIYG68yxncACsUaG4ZeMWpEpM6tWgNj+zYBEAFp04qqAzv+pnjH8JUFHdia10sqKYMy7SAl/zKxxk9RVw1gMYdcfN0pX3NDyijGN9MQVTodGwdIIhHVSYNZtngQd2ePMXU7FpvFDeQ0l8Curyg= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1661336118; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=trWpCFmc885+Hbmydl7kHMuVBjh6162eTb0KUJVdu8M=; b=J+Iy7uNJggo7qhrgeXp9Q1xEFWZ5QAxkwGUYCoPGisdtsRFBX0qllMTWSs6HL9jufEWsVhrAhSAeDAQcjT4rZBegQeedt71i3b2ssQBP1BqFtWEL4YUbYdiO3MitIuThfXeW+bJFNYx9jluMt+U5QHAsgsAM5soiWfQ0hsh5nFU= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass header.from= (p=none dis=none) Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1661336118629752.9208139182275; Wed, 24 Aug 2022 03:15:18 -0700 (PDT) Received: from localhost ([::1]:37542 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1oQnPp-00039Y-Dj for importer@patchew.org; Wed, 24 Aug 2022 06:15:17 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:46386) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1oQmte-0002ul-Jg; Wed, 24 Aug 2022 05:42:04 -0400 Received: from mail-pj1-x1030.google.com ([2607:f8b0:4864:20::1030]:53904) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1oQmtb-0001WD-BT; Wed, 24 Aug 2022 05:42:02 -0400 Received: by mail-pj1-x1030.google.com with SMTP id m15so8460677pjj.3; Wed, 24 Aug 2022 02:41:58 -0700 (PDT) Received: from ubuntu.. (144.168.56.201.16clouds.com. [144.168.56.201]) by smtp.gmail.com with ESMTPSA id b14-20020a170903228e00b001728eb339e2sm12165972plh.286.2022.08.24.02.41.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 24 Aug 2022 02:41:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc; bh=trWpCFmc885+Hbmydl7kHMuVBjh6162eTb0KUJVdu8M=; b=e0Yaknpcgf7hBFJYxusqzUm+qOvpcJiD8u/ZjdYt5t2m77MNIt9MJmkhQo1uvXbB8b pZmwqbNZd4s2n6+rnFvgbQDSnIWQHxWyc6JkyLm+NR/+OdQiTc/sIxpDKefmsGdtynr7 uFjOuhym6YYTDOvE+mv5gzgcBQuzEPvsemoJSEa/np63O6tqElukz2SAuzytK2o3BIlf xDbbQS/iEYd84GbYqDDKBdF7V45lClKOs6KZQMJeyz+Uzl0OOv/RS+gKgVchz6BzGB0m 5x2fufRzaPX3i7e6jgTXbKy/iv+/s78dFh3ldZ1BPi3yETgeA/BklUYNrEXeNzMg2sh4 /jTA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc; bh=trWpCFmc885+Hbmydl7kHMuVBjh6162eTb0KUJVdu8M=; b=oA4w7fmXQgrTS1p89D3qSTfQ42glCHq3yWSyS945quHTW+7VNu6qUnQxg31L1JKil5 ReN+J+d3nOJFQfzdFBWVVkMFVB0KQPubRh+DMqGOCZ02ZAqofo2CWlOAtV787QvtxIWK 13bzMHxBYutbpUK3n6KsJdJNeVsKIdQtGnFfhqkaFX7DwlT9Oeije3lXoB/Q9Sho7sa2 FtDA9MH/MestvwwPY7h8wCRYwWOKiza47lrWQtqFciGDx/ppiUOqZg0q9BhqzvsuKoA3 WDjdMWBokvtFKLXBiLQmkrYz5j0icoeJEUH5CON52hZDbsM2/BVwV+nmVneBeRKovb6b cgRw== X-Gm-Message-State: ACgBeo1A3eG8xGuW6rVRKJSn3GLmTQbN+Z/vhz/CS+84LPrtpZS6eLy4 C0e7SP1BJ6/Tubv1pOq3YbiSXCYXuxA= X-Google-Smtp-Source: AA6agR5ZfEBiPtMraGoKOQIiglSQYZKltjyt4Ctsz31RHVPE07kuVgMYzkojKpeldWJhnZy4GQeGyQ== X-Received: by 2002:a17:902:8bc7:b0:172:c32f:7d30 with SMTP id r7-20020a1709028bc700b00172c32f7d30mr22188206plo.48.1661334116753; Wed, 24 Aug 2022 02:41:56 -0700 (PDT) From: Bin Meng To: qemu-devel@nongnu.org Cc: Bin Meng , Alexander Bulekov , Andrew Jeffery , Bandan Das , Coiby Xu , =?UTF-8?q?C=C3=A9dric=20Le=20Goater?= , Darren Kenny , "Dr. David Alan Gilbert" , Fam Zheng , Joel Stanley , John Snow , Juan Quintela , Konstantin Kostiuk , Laurent Vivier , Markus Armbruster , Michael Roth , Paolo Bonzini , Peter Maydell , Qiuhao Li , Stefan Hajnoczi , Thomas Huth , qemu-arm@nongnu.org, qemu-block@nongnu.org Subject: [PATCH 07/51] tests: Avoid using hardcoded /tmp in test cases Date: Wed, 24 Aug 2022 17:39:45 +0800 Message-Id: <20220824094029.1634519-8-bmeng.cn@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220824094029.1634519-1-bmeng.cn@gmail.com> References: <20220824094029.1634519-1-bmeng.cn@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=2607:f8b0:4864:20::1030; envelope-from=bmeng.cn@gmail.com; helo=mail-pj1-x1030.google.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, FREEMAIL_FROM=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: pass (identity @gmail.com) X-ZM-MESSAGEID: 1661336119726100001 Content-Type: text/plain; charset="utf-8" From: Bin Meng Use g_get_tmp_dir() to get the directory to use for temporary files. Signed-off-by: Bin Meng --- tests/qtest/fuzz/generic_fuzz_configs.h | 6 ++++-- tests/qtest/ahci-test.c | 15 +++++++++++---- tests/qtest/aspeed_smc-test.c | 4 +++- tests/qtest/boot-serial-test.c | 8 ++++++-- tests/qtest/cxl-test.c | 9 ++++++--- tests/qtest/fdc-test.c | 4 +++- tests/qtest/fuzz/virtio_blk_fuzz.c | 2 +- tests/qtest/hd-geo-test.c | 8 ++++---- tests/qtest/ide-test.c | 8 ++++++-- tests/qtest/libqtest.c | 10 +++++++--- tests/qtest/migration-test.c | 4 +++- tests/qtest/pflash-cfi02-test.c | 7 +++++-- tests/qtest/qmp-test.c | 4 +++- tests/qtest/vhost-user-blk-test.c | 3 ++- tests/qtest/vhost-user-test.c | 3 ++- tests/qtest/virtio-blk-test.c | 2 +- tests/qtest/virtio-scsi-test.c | 3 ++- tests/unit/test-image-locking.c | 6 ++++-- tests/unit/test-qga.c | 2 +- tests/vhost-user-bridge.c | 3 ++- 20 files changed, 76 insertions(+), 35 deletions(-) diff --git a/tests/qtest/fuzz/generic_fuzz_configs.h b/tests/qtest/fuzz/gen= eric_fuzz_configs.h index 0775e6702b..d0f9961187 100644 --- a/tests/qtest/fuzz/generic_fuzz_configs.h +++ b/tests/qtest/fuzz/generic_fuzz_configs.h @@ -20,13 +20,15 @@ typedef struct generic_fuzz_config { } generic_fuzz_config; =20 static inline gchar *generic_fuzzer_virtio_9p_args(void){ - char tmpdir[] =3D "/tmp/qemu-fuzz.XXXXXX"; + char *tmpdir =3D g_strdup_printf("%s/qemu-fuzz.XXXXXX", g_get_tmp_dir(= )); g_assert_nonnull(g_mkdtemp(tmpdir)); =20 - return g_strdup_printf("-machine q35 -nodefaults " + gchar *args =3D g_strdup_printf("-machine q35 -nodefaults " "-device virtio-9p,fsdev=3Dhshare,mount_tag=3Dhshare " "-fsdev local,id=3Dhshare,path=3D%s,security_model=3Dmapped-xattr," "writeout=3Dimmediate,fmode=3D0600,dmode=3D0700", tmpdir); + g_free(tmpdir); + return args; } =20 const generic_fuzz_config predefined_configs[] =3D { diff --git a/tests/qtest/ahci-test.c b/tests/qtest/ahci-test.c index f1e510b0ac..f26cd6f86f 100644 --- a/tests/qtest/ahci-test.c +++ b/tests/qtest/ahci-test.c @@ -44,9 +44,9 @@ #define TEST_IMAGE_SIZE_MB_SMALL 64 =20 /*** Globals ***/ -static char tmp_path[] =3D "/tmp/qtest.XXXXXX"; -static char debug_path[] =3D "/tmp/qtest-blkdebug.XXXXXX"; -static char mig_socket[] =3D "/tmp/qtest-migration.XXXXXX"; +static char *tmp_path; +static char *debug_path; +static char *mig_socket; static bool ahci_pedantic; static const char *imgfmt; static unsigned test_image_size_mb; @@ -1437,7 +1437,7 @@ static void test_ncq_simple(void) =20 static int prepare_iso(size_t size, unsigned char **buf, char **name) { - char cdrom_path[] =3D "/tmp/qtest.iso.XXXXXX"; + char *cdrom_path =3D g_strdup_printf("%s/qtest.iso.XXXXXX", g_get_tmp_= dir()); unsigned char *patt; ssize_t ret; int fd =3D mkstemp(cdrom_path); @@ -1454,6 +1454,7 @@ static int prepare_iso(size_t size, unsigned char **b= uf, char **name) =20 *name =3D g_strdup(cdrom_path); *buf =3D patt; + g_free(cdrom_path); return fd; } =20 @@ -1872,6 +1873,7 @@ int main(int argc, char **argv) } =20 /* Create a temporary image */ + tmp_path =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); fd =3D mkstemp(tmp_path); g_assert(fd >=3D 0); if (have_qemu_img()) { @@ -1889,11 +1891,13 @@ int main(int argc, char **argv) close(fd); =20 /* Create temporary blkdebug instructions */ + debug_path =3D g_strdup_printf("%s/qtest-blkdebug.XXXXXX", g_get_tmp_d= ir()); fd =3D mkstemp(debug_path); g_assert(fd >=3D 0); close(fd); =20 /* Reserve a hollow file to use as a socket for migration tests */ + mig_socket =3D g_strdup_printf("%s/qtest-migration.XXXXXX", g_get_tmp_= dir()); fd =3D mkstemp(mig_socket); g_assert(fd >=3D 0); close(fd); @@ -1947,8 +1951,11 @@ int main(int argc, char **argv) =20 /* Cleanup */ unlink(tmp_path); + g_free(tmp_path); unlink(debug_path); + g_free(debug_path); unlink(mig_socket); + g_free(mig_socket); =20 return ret; } diff --git a/tests/qtest/aspeed_smc-test.c b/tests/qtest/aspeed_smc-test.c index 05ce941566..cab769459c 100644 --- a/tests/qtest/aspeed_smc-test.c +++ b/tests/qtest/aspeed_smc-test.c @@ -608,7 +608,7 @@ static void test_write_block_protect_bottom_bit(void) flash_reset(); } =20 -static char tmp_path[] =3D "/tmp/qtest.m25p80.XXXXXX"; +static char *tmp_path; =20 int main(int argc, char **argv) { @@ -617,6 +617,7 @@ int main(int argc, char **argv) =20 g_test_init(&argc, &argv, NULL); =20 + tmp_path =3D g_strdup_printf("%s/qtest.m25p80.XXXXXX", g_get_tmp_dir()= ); fd =3D mkstemp(tmp_path); g_assert(fd >=3D 0); ret =3D ftruncate(fd, FLASH_SIZE); @@ -646,5 +647,6 @@ int main(int argc, char **argv) =20 qtest_quit(global_qtest); unlink(tmp_path); + g_free(tmp_path); return ret; } diff --git a/tests/qtest/boot-serial-test.c b/tests/qtest/boot-serial-test.c index 2f99d71cab..404adcfa20 100644 --- a/tests/qtest/boot-serial-test.c +++ b/tests/qtest/boot-serial-test.c @@ -224,8 +224,10 @@ static bool check_guest_output(QTestState *qts, const = testdef_t *test, int fd) static void test_machine(const void *data) { const testdef_t *test =3D data; - char serialtmp[] =3D "/tmp/qtest-boot-serial-sXXXXXX"; - char codetmp[] =3D "/tmp/qtest-boot-serial-cXXXXXX"; + char *serialtmp =3D g_strdup_printf("%s/qtest-boot-serial-sXXXXXX", + g_get_tmp_dir()); + char *codetmp =3D g_strdup_printf("%s/qtest-boot-serial-cXXXXXX", + g_get_tmp_dir()); const char *codeparam =3D ""; const uint8_t *code =3D NULL; QTestState *qts; @@ -264,6 +266,7 @@ static void test_machine(const void *data) serialtmp, test->extra); if (code) { unlink(codetmp); + g_free(codetmp); } =20 if (!check_guest_output(qts, test, ser_fd)) { @@ -271,6 +274,7 @@ static void test_machine(const void *data) serialtmp); } unlink(serialtmp); + g_free(serialtmp); =20 qtest_quit(qts); =20 diff --git a/tests/qtest/cxl-test.c b/tests/qtest/cxl-test.c index 4e6d285061..b3733cdb5f 100644 --- a/tests/qtest/cxl-test.c +++ b/tests/qtest/cxl-test.c @@ -92,12 +92,13 @@ static void cxl_2root_port(void) static void cxl_t3d(void) { g_autoptr(GString) cmdline =3D g_string_new(NULL); - char template[] =3D "/tmp/cxl-test-XXXXXX"; + char *template =3D g_strdup_printf("%s/cxl-test-XXXXXX", g_get_tmp_dir= ()); const char *tmpfs; =20 tmpfs =3D g_mkdtemp(template); =20 g_string_printf(cmdline, QEMU_PXB_CMD QEMU_RP QEMU_T3D, tmpfs, tmpfs); + g_free(template); =20 qtest_start(cmdline->str); qtest_end(); @@ -106,13 +107,14 @@ static void cxl_t3d(void) static void cxl_1pxb_2rp_2t3d(void) { g_autoptr(GString) cmdline =3D g_string_new(NULL); - char template[] =3D "/tmp/cxl-test-XXXXXX"; + char *template =3D g_strdup_printf("%s/cxl-test-XXXXXX", g_get_tmp_dir= ()); const char *tmpfs; =20 tmpfs =3D g_mkdtemp(template); =20 g_string_printf(cmdline, QEMU_PXB_CMD QEMU_2RP QEMU_2T3D, tmpfs, tmpfs, tmpfs, tmpfs); + g_free(template); =20 qtest_start(cmdline->str); qtest_end(); @@ -121,7 +123,7 @@ static void cxl_1pxb_2rp_2t3d(void) static void cxl_2pxb_4rp_4t3d(void) { g_autoptr(GString) cmdline =3D g_string_new(NULL); - char template[] =3D "/tmp/cxl-test-XXXXXX"; + char *template =3D g_strdup_printf("%s/cxl-test-XXXXXX", g_get_tmp_dir= ()); const char *tmpfs; =20 tmpfs =3D g_mkdtemp(template); @@ -129,6 +131,7 @@ static void cxl_2pxb_4rp_4t3d(void) g_string_printf(cmdline, QEMU_2PXB_CMD QEMU_4RP QEMU_4T3D, tmpfs, tmpfs, tmpfs, tmpfs, tmpfs, tmpfs, tmpfs, tmpfs); + g_free(template); =20 qtest_start(cmdline->str); qtest_end(); diff --git a/tests/qtest/fdc-test.c b/tests/qtest/fdc-test.c index 52ade90a7d..8651100b05 100644 --- a/tests/qtest/fdc-test.c +++ b/tests/qtest/fdc-test.c @@ -68,7 +68,7 @@ enum { DSKCHG =3D 0x80, }; =20 -static char test_image[] =3D "/tmp/qtest.XXXXXX"; +static char *test_image; =20 #define assert_bit_set(data, mask) g_assert_cmphex((data) & (mask), =3D=3D= , (mask)) #define assert_bit_clear(data, mask) g_assert_cmphex((data) & (mask), =3D= =3D, 0) @@ -608,6 +608,7 @@ int main(int argc, char **argv) int ret; =20 /* Create a temporary raw image */ + test_image =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); fd =3D mkstemp(test_image); g_assert(fd >=3D 0); ret =3D ftruncate(fd, TEST_IMAGE_SIZE); @@ -640,6 +641,7 @@ int main(int argc, char **argv) /* Cleanup */ qtest_end(); unlink(test_image); + g_free(test_image); =20 return ret; } diff --git a/tests/qtest/fuzz/virtio_blk_fuzz.c b/tests/qtest/fuzz/virtio_b= lk_fuzz.c index 236d078cc8..3e9541a38a 100644 --- a/tests/qtest/fuzz/virtio_blk_fuzz.c +++ b/tests/qtest/fuzz/virtio_blk_fuzz.c @@ -181,7 +181,7 @@ static void drive_destroy(void *path) static char *drive_create(void) { int fd, ret; - char *t_path =3D g_strdup("/tmp/qtest.XXXXXX"); + char *t_path =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); =20 /* Create a temporary raw image */ fd =3D mkstemp(t_path); diff --git a/tests/qtest/hd-geo-test.c b/tests/qtest/hd-geo-test.c index 413cf964c0..dc5d8422ea 100644 --- a/tests/qtest/hd-geo-test.c +++ b/tests/qtest/hd-geo-test.c @@ -27,7 +27,7 @@ =20 static char *create_test_img(int secs) { - char *template =3D strdup("/tmp/qtest.XXXXXX"); + char *template =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); int fd, ret; =20 fd =3D mkstemp(template); @@ -36,7 +36,7 @@ static char *create_test_img(int secs) close(fd); =20 if (ret) { - free(template); + g_free(template); template =3D NULL; } =20 @@ -422,7 +422,7 @@ static MBRpartitions empty_mbr =3D { {false, 0, 0, 0, 0= , 0, 0, 0, 0}, =20 static char *create_qcow2_with_mbr(MBRpartitions mbr, uint64_t sectors) { - const char *template =3D "/tmp/qtest.XXXXXX"; + const char *template =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_= dir()); char *raw_path =3D strdup(template); char *qcow2_path =3D strdup(template); char cmd[100 + 2 * PATH_MAX]; @@ -987,7 +987,7 @@ test_add_done: for (i =3D 0; i < backend_last; i++) { if (img_file_name[i]) { unlink(img_file_name[i]); - free(img_file_name[i]); + g_free(img_file_name[i]); } } =20 diff --git a/tests/qtest/ide-test.c b/tests/qtest/ide-test.c index 5bcb75a7e5..ebbf8e0126 100644 --- a/tests/qtest/ide-test.c +++ b/tests/qtest/ide-test.c @@ -121,8 +121,8 @@ enum { static QPCIBus *pcibus =3D NULL; static QGuestAllocator guest_malloc; =20 -static char tmp_path[] =3D "/tmp/qtest.XXXXXX"; -static char debug_path[] =3D "/tmp/qtest-blkdebug.XXXXXX"; +static char *tmp_path; +static char *debug_path; =20 static QTestState *ide_test_start(const char *cmdline_fmt, ...) { @@ -1015,11 +1015,13 @@ int main(int argc, char **argv) int ret; =20 /* Create temporary blkdebug instructions */ + debug_path =3D g_strdup_printf("%s/qtest-blkdebug.XXXXXX", g_get_tmp_d= ir()); fd =3D mkstemp(debug_path); g_assert(fd >=3D 0); close(fd); =20 /* Create a temporary raw image */ + tmp_path =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); fd =3D mkstemp(tmp_path); g_assert(fd >=3D 0); ret =3D ftruncate(fd, TEST_IMAGE_SIZE); @@ -1049,7 +1051,9 @@ int main(int argc, char **argv) =20 /* Cleanup */ unlink(tmp_path); + g_free(tmp_path); unlink(debug_path); + g_free(debug_path); =20 return ret; } diff --git a/tests/qtest/libqtest.c b/tests/qtest/libqtest.c index 7c9fc07de4..34744ace7c 100644 --- a/tests/qtest/libqtest.c +++ b/tests/qtest/libqtest.c @@ -265,8 +265,10 @@ QTestState *qtest_init_without_qmp_handshake(const cha= r *extra_args) =20 s =3D g_new(QTestState, 1); =20 - socket_path =3D g_strdup_printf("/tmp/qtest-%d.sock", getpid()); - qmp_socket_path =3D g_strdup_printf("/tmp/qtest-%d.qmp", getpid()); + socket_path =3D g_strdup_printf("%s/qtest-%d.sock", + g_get_tmp_dir(), getpid()); + qmp_socket_path =3D g_strdup_printf("%s/qtest-%d.qmp", + g_get_tmp_dir(), getpid()); =20 /* It's possible that if an earlier test run crashed it might * have left a stale unix socket lying around. Delete any @@ -390,9 +392,10 @@ QTestState *qtest_initf(const char *fmt, ...) QTestState *qtest_init_with_serial(const char *extra_args, int *sock_fd) { int sock_fd_init; - char *sock_path, sock_dir[] =3D "/tmp/qtest-serial-XXXXXX"; + char *sock_path, *sock_dir; QTestState *qts; =20 + sock_dir =3D g_strdup_printf("%s/qtest-serial-XXXXXX", g_get_tmp_dir()= ); g_assert_true(g_mkdtemp(sock_dir) !=3D NULL); sock_path =3D g_strdup_printf("%s/sock", sock_dir); =20 @@ -406,6 +409,7 @@ QTestState *qtest_init_with_serial(const char *extra_ar= gs, int *sock_fd) unlink(sock_path); g_free(sock_path); rmdir(sock_dir); + g_free(sock_dir); =20 g_assert_true(*sock_fd >=3D 0); =20 diff --git a/tests/qtest/migration-test.c b/tests/qtest/migration-test.c index 52988b86eb..5fa4ffeff0 100644 --- a/tests/qtest/migration-test.c +++ b/tests/qtest/migration-test.c @@ -2422,7 +2422,8 @@ static bool kvm_dirty_ring_supported(void) =20 int main(int argc, char **argv) { - char template[] =3D "/tmp/migration-test-XXXXXX"; + char *template =3D g_strdup_printf("%s/migration-test-XXXXXX", + g_get_tmp_dir()); const bool has_kvm =3D qtest_has_accel("kvm"); const bool has_uffd =3D ufd_version_check(); const char *arch =3D qtest_get_arch(); @@ -2576,6 +2577,7 @@ int main(int argc, char **argv) g_test_message("unable to rmdir: path (%s): %s", tmpfs, strerror(errno)); } + g_free(template); =20 return ret; } diff --git a/tests/qtest/pflash-cfi02-test.c b/tests/qtest/pflash-cfi02-tes= t.c index 7fce614b64..6de83717dd 100644 --- a/tests/qtest/pflash-cfi02-test.c +++ b/tests/qtest/pflash-cfi02-test.c @@ -56,7 +56,7 @@ typedef struct { QTestState *qtest; } FlashConfig; =20 -static char image_path[] =3D "/tmp/qtest.XXXXXX"; +static char *image_path; =20 /* * The pflash implementation allows some parameters to be unspecified. We = want @@ -608,6 +608,7 @@ static void test_cfi_in_autoselect(const void *opaque) static void cleanup(void *opaque) { unlink(image_path); + g_free(image_path); } =20 /* @@ -635,16 +636,18 @@ static const FlashConfig configuration[] =3D { =20 int main(int argc, char **argv) { + image_path =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); int fd =3D mkstemp(image_path); if (fd =3D=3D -1) { g_printerr("Failed to create temporary file %s: %s\n", image_path, strerror(errno)); + g_free(image_path); exit(EXIT_FAILURE); } if (ftruncate(fd, UNIFORM_FLASH_SIZE) < 0) { int error_code =3D errno; close(fd); - unlink(image_path); + cleanup(NULL); g_printerr("Failed to truncate file %s to %u MB: %s\n", image_path, UNIFORM_FLASH_SIZE, strerror(error_code)); exit(EXIT_FAILURE); diff --git a/tests/qtest/qmp-test.c b/tests/qtest/qmp-test.c index bf7304c7dc..b950dbafaf 100644 --- a/tests/qtest/qmp-test.c +++ b/tests/qtest/qmp-test.c @@ -161,11 +161,12 @@ static void test_qmp_protocol(void) =20 /* Out-of-band tests */ =20 -char tmpdir[] =3D "/tmp/qmp-test-XXXXXX"; +char *tmpdir; char *fifo_name; =20 static void setup_blocking_cmd(void) { + tmpdir =3D g_strdup_printf("%s/qmp-test-XXXXXX", g_get_tmp_dir()); if (!g_mkdtemp(tmpdir)) { g_error("g_mkdtemp: %s", strerror(errno)); } @@ -179,6 +180,7 @@ static void cleanup_blocking_cmd(void) { unlink(fifo_name); rmdir(tmpdir); + g_free(tmpdir); } =20 static void send_cmd_that_blocks(QTestState *s, const char *id) diff --git a/tests/qtest/vhost-user-blk-test.c b/tests/qtest/vhost-user-blk= -test.c index a81c2a2715..07a4c2d500 100644 --- a/tests/qtest/vhost-user-blk-test.c +++ b/tests/qtest/vhost-user-blk-test.c @@ -841,7 +841,8 @@ static char *create_listen_socket(int *fd) char *path; =20 /* No race because our pid makes the path unique */ - path =3D g_strdup_printf("/tmp/qtest-%d-sock.XXXXXX", getpid()); + path =3D g_strdup_printf("%s/qtest-%d-sock.XXXXXX", + g_get_tmp_dir(), getpid()); tmp_fd =3D mkstemp(path); g_assert_cmpint(tmp_fd, >=3D, 0); close(tmp_fd); diff --git a/tests/qtest/vhost-user-test.c b/tests/qtest/vhost-user-test.c index d7d6cfc9bd..a41168de25 100644 --- a/tests/qtest/vhost-user-test.c +++ b/tests/qtest/vhost-user-test.c @@ -482,7 +482,7 @@ static TestServer *test_server_new(const gchar *name, struct vhost_user_ops *ops) { TestServer *server =3D g_new0(TestServer, 1); - char template[] =3D "/tmp/vhost-test-XXXXXX"; + char *template =3D g_strdup_printf("%s/vhost-test-XXXXXX", g_get_tmp_d= ir()); const char *tmpfs; =20 server->context =3D g_main_context_new(); @@ -501,6 +501,7 @@ static TestServer *test_server_new(const gchar *name, server->socket_path =3D g_strdup_printf("%s/%s.sock", tmpfs, name); server->mig_path =3D g_strdup_printf("%s/%s.mig", tmpfs, name); server->chr_name =3D g_strdup_printf("chr-%s", name); + g_free(template); =20 g_mutex_init(&server->data_mutex); g_cond_init(&server->data_cond); diff --git a/tests/qtest/virtio-blk-test.c b/tests/qtest/virtio-blk-test.c index dc5eed31c8..8920ce7c46 100644 --- a/tests/qtest/virtio-blk-test.c +++ b/tests/qtest/virtio-blk-test.c @@ -49,7 +49,7 @@ static void drive_destroy(void *path) static char *drive_create(void) { int fd, ret; - char *t_path =3D g_strdup("/tmp/qtest.XXXXXX"); + char *t_path =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); =20 /* Create a temporary raw image */ fd =3D mkstemp(t_path); diff --git a/tests/qtest/virtio-scsi-test.c b/tests/qtest/virtio-scsi-test.c index 8ceb12aacd..33ab6ec685 100644 --- a/tests/qtest/virtio-scsi-test.c +++ b/tests/qtest/virtio-scsi-test.c @@ -268,7 +268,7 @@ static void test_iothread_attach_node(void *obj, void *= data, QVirtioSCSIPCI *scsi_pci =3D obj; QVirtioSCSI *scsi =3D &scsi_pci->scsi; QVirtioSCSIQueues *vs; - char tmp_path[] =3D "/tmp/qtest.XXXXXX"; + char *tmp_path =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); int fd; int ret; =20 @@ -309,6 +309,7 @@ static void test_iothread_attach_node(void *obj, void *= data, fail: qvirtio_scsi_pci_free(vs); unlink(tmp_path); + g_free(tmp_path); } =20 static void *virtio_scsi_hotplug_setup(GString *cmd_line, void *arg) diff --git a/tests/unit/test-image-locking.c b/tests/unit/test-image-lockin= g.c index ba057bd66c..795c602ff6 100644 --- a/tests/unit/test-image-locking.c +++ b/tests/unit/test-image-locking.c @@ -76,7 +76,7 @@ static void check_locked_bytes(int fd, uint64_t perm_lock= s, static void test_image_locking_basic(void) { BlockBackend *blk1, *blk2, *blk3; - char img_path[] =3D "/tmp/qtest.XXXXXX"; + char *img_path =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); uint64_t perm, shared_perm; =20 int fd =3D mkstemp(img_path); @@ -112,12 +112,13 @@ static void test_image_locking_basic(void) blk_unref(blk3); close(fd); unlink(img_path); + g_free(img_path); } =20 static void test_set_perm_abort(void) { BlockBackend *blk1, *blk2; - char img_path[] =3D "/tmp/qtest.XXXXXX"; + char *img_path =3D g_strdup_printf("%s/qtest.XXXXXX", g_get_tmp_dir()); uint64_t perm, shared_perm; int r; int fd =3D mkstemp(img_path); @@ -140,6 +141,7 @@ static void test_set_perm_abort(void) check_locked_bytes(fd, perm, ~shared_perm); blk_unref(blk1); blk_unref(blk2); + g_free(img_path); } =20 int main(int argc, char **argv) diff --git a/tests/unit/test-qga.c b/tests/unit/test-qga.c index a05a4628ed..b73d231cd5 100644 --- a/tests/unit/test-qga.c +++ b/tests/unit/test-qga.c @@ -59,7 +59,7 @@ fixture_setup(TestFixture *fixture, gconstpointer data, g= char **envp) =20 fixture->loop =3D g_main_loop_new(NULL, FALSE); =20 - fixture->test_dir =3D g_strdup("/tmp/qgatest.XXXXXX"); + fixture->test_dir =3D g_strdup_printf("%s/qgatest.XXXXXX", g_get_tmp_d= ir()); g_assert_nonnull(g_mkdtemp(fixture->test_dir)); =20 path =3D g_build_filename(fixture->test_dir, "sock", NULL); diff --git a/tests/vhost-user-bridge.c b/tests/vhost-user-bridge.c index 9b1dab2f28..0da6a6157f 100644 --- a/tests/vhost-user-bridge.c +++ b/tests/vhost-user-bridge.c @@ -631,7 +631,7 @@ static void *notifier_thread(void *arg) static void vubr_host_notifier_setup(VubrDev *dev) { - char template[] =3D "/tmp/vubr-XXXXXX"; + char *template =3D g_strdup_printf("%s/vubr-XXXXXX", g_get_tmp_dir()); pthread_t thread; size_t length; void *addr; @@ -640,6 +640,7 @@ vubr_host_notifier_setup(VubrDev *dev) length =3D qemu_real_host_page_size() * VHOST_USER_BRIDGE_MAX_QUEUES; =20 fd =3D mkstemp(template); + g_free(template); if (fd < 0) { vubr_die("mkstemp()"); } --=20 2.34.1