2017-09-21 22:26:06 +03:00
/*
2016-03-02 18:05:08 +03:00
* Copyright ( C ) 2015 Red Hat , Inc .
*
2018-01-30 22:26:26 +03:00
* SPDX - License - Identifier : LGPL - 2.0 +
*
2016-03-02 18:05:08 +03:00
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2 of the License , or ( at your option ) any later version .
*
* This library 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
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
2021-12-07 04:20:55 +03:00
* License along with this library . If not , see < https : //www.gnu.org/licenses/>.
2016-03-02 18:05:08 +03:00
*/
# include "config.h"
# include <stdlib.h>
# include <string.h>
# include "libglnx.h"
# include "libostreetest.h"
/* This function hovers in a quantum superposition of horrifying and
* beautiful . Future generations may interpret it as modern art .
*/
2016-06-06 21:49:11 +03:00
gboolean
ot_test_run_libtest ( const char * cmd , GError * * error )
2016-03-02 18:05:08 +03:00
{
2016-06-12 16:21:19 +03:00
const char * srcdir = g_getenv ( " G_TEST_SRCDIR " ) ;
2021-12-10 14:29:29 +03:00
g_assert ( srcdir ! = NULL ) ;
g_assert ( cmd ! = NULL ) ;
2016-03-02 18:05:08 +03:00
2023-05-01 21:24:29 +03:00
g_autoptr ( GPtrArray ) argv = g_ptr_array_new ( ) ;
2016-03-02 18:05:08 +03:00
g_ptr_array_add ( argv , " bash " ) ;
g_ptr_array_add ( argv , " -c " ) ;
2023-05-01 21:24:29 +03:00
g_autoptr ( GString ) cmdstr = g_string_new ( " " ) ;
2016-06-06 22:00:13 +03:00
g_string_append ( cmdstr , " set -xeuo pipefail; . " ) ;
2016-06-12 16:21:19 +03:00
g_string_append ( cmdstr , srcdir ) ;
2016-03-02 18:05:08 +03:00
g_string_append ( cmdstr , " /tests/libtest.sh; " ) ;
g_string_append ( cmdstr , cmd ) ;
g_ptr_array_add ( argv , cmdstr - > str ) ;
g_ptr_array_add ( argv , NULL ) ;
2017-09-13 19:09:51 +03:00
int estatus ;
2023-05-01 21:24:29 +03:00
if ( ! g_spawn_sync ( NULL , ( char * * ) argv - > pdata , NULL , G_SPAWN_SEARCH_PATH , NULL , NULL , NULL , NULL ,
& estatus , error ) )
2017-09-13 19:09:51 +03:00
return FALSE ;
2016-03-02 18:05:08 +03:00
if ( ! g_spawn_check_exit_status ( estatus , error ) )
2017-09-13 19:09:51 +03:00
return FALSE ;
2016-03-02 18:05:08 +03:00
2017-09-13 19:09:51 +03:00
return TRUE ;
2016-03-02 18:05:08 +03:00
}
2016-03-03 21:49:54 +03:00
OstreeRepo *
2023-05-01 21:24:29 +03:00
ot_test_setup_repo ( GCancellable * cancellable , GError * * error )
2016-03-02 18:05:08 +03:00
{
2017-09-01 23:15:33 +03:00
if ( ! ot_test_run_libtest ( " setup_test_repository archive " , error ) )
2017-09-13 19:09:51 +03:00
return NULL ;
2016-03-02 18:05:08 +03:00
2023-05-01 21:24:29 +03:00
g_autoptr ( GFile ) repo_path = g_file_new_for_path ( " repo " ) ;
g_autoptr ( OstreeRepo ) ret_repo = ostree_repo_new ( repo_path ) ;
2016-03-03 21:49:54 +03:00
if ( ! ostree_repo_open ( ret_repo , cancellable , error ) )
2017-09-13 19:09:51 +03:00
return NULL ;
2016-03-02 18:05:08 +03:00
2017-09-13 19:09:51 +03:00
return g_steal_pointer ( & ret_repo ) ;
2016-03-03 21:49:54 +03:00
}
2017-09-28 21:57:33 +03:00
/* Determine whether we're able to relabel files. Needed for bare tests. */
gboolean
2023-05-01 21:24:29 +03:00
ot_check_relabeling ( gboolean * can_relabel , GError * * error )
2017-09-28 21:57:33 +03:00
{
2023-05-01 21:24:29 +03:00
g_auto ( GLnxTmpfile ) tmpf = {
0 ,
} ;
2017-09-28 21:57:33 +03:00
if ( ! glnx_open_tmpfile_linkable_at ( AT_FDCWD , " . " , O_RDWR | O_CLOEXEC , & tmpf , error ) )
return FALSE ;
2023-05-01 21:24:29 +03:00
g_autoptr ( GError ) local_error = NULL ;
g_autoptr ( GBytes ) bytes = glnx_fgetxattr_bytes ( tmpf . fd , " security.selinux " , & local_error ) ;
2017-09-28 21:57:33 +03:00
if ( ! bytes )
{
2017-10-16 14:51:04 +03:00
/* libglnx preserves errno. The EOPNOTSUPP case can't be part of a
* ' case ' statement because on most but not all architectures ,
* it ' s numerically equal to ENOTSUP . */
if ( G_IN_SET ( errno , ENOTSUP , ENODATA ) | | errno = = EOPNOTSUPP )
2017-09-28 21:57:33 +03:00
{
* can_relabel = FALSE ;
return TRUE ;
}
g_propagate_error ( error , g_steal_pointer ( & local_error ) ) ;
return FALSE ;
}
gsize data_len ;
const guint8 * data = g_bytes_get_data ( bytes , & data_len ) ;
if ( fsetxattr ( tmpf . fd , " security.selinux " , data , data_len , 0 ) < 0 )
{
2017-10-16 14:51:04 +03:00
if ( errno = = ENOTSUP | | errno = = EOPNOTSUPP )
2017-09-28 21:57:33 +03:00
{
* can_relabel = FALSE ;
return TRUE ;
}
return glnx_throw_errno_prefix ( error , " fsetxattr " ) ;
}
* can_relabel = TRUE ;
return TRUE ;
}
/* Determine whether the filesystem supports getting/setting user xattrs. */
gboolean
2023-05-01 21:24:29 +03:00
ot_check_user_xattrs ( gboolean * has_user_xattrs , GError * * error )
2017-09-28 21:57:33 +03:00
{
2023-05-01 21:24:29 +03:00
g_auto ( GLnxTmpfile ) tmpf = {
0 ,
} ;
2017-09-28 21:57:33 +03:00
if ( ! glnx_open_tmpfile_linkable_at ( AT_FDCWD , " . " , O_RDWR | O_CLOEXEC , & tmpf , error ) )
return FALSE ;
if ( fsetxattr ( tmpf . fd , " user.test " , " novalue " , strlen ( " novalue " ) , 0 ) < 0 )
{
2017-10-16 14:51:04 +03:00
if ( errno = = ENOTSUP | | errno = = EOPNOTSUPP )
2017-09-28 21:57:33 +03:00
{
* has_user_xattrs = FALSE ;
return TRUE ;
}
return glnx_throw_errno_prefix ( error , " fsetxattr " ) ;
}
* has_user_xattrs = TRUE ;
return TRUE ;
}
2016-03-03 21:49:54 +03:00
OstreeSysroot *
2023-05-01 21:24:29 +03:00
ot_test_setup_sysroot ( GCancellable * cancellable , GError * * error )
2016-03-03 21:49:54 +03:00
{
2017-09-01 23:15:33 +03:00
if ( ! ot_test_run_libtest ( " setup_os_repository \" archive \" \" syslinux \" " , error ) )
2017-09-13 19:09:51 +03:00
return FALSE ;
2016-03-03 21:49:54 +03:00
2023-05-01 21:24:29 +03:00
g_autoptr ( GString ) buf = g_string_new ( " mutable-deployments " ) ;
2017-09-28 21:57:33 +03:00
2019-10-18 17:57:47 +03:00
gboolean can_relabel = FALSE ;
2017-09-28 21:57:33 +03:00
if ( ! ot_check_relabeling ( & can_relabel , error ) )
return FALSE ;
if ( ! can_relabel )
{
g_print ( " libostreetest: can't relabel, turning off xattrs \n " ) ;
g_string_append ( buf , " ,no-xattrs " ) ;
}
/* Make sure deployments are mutable */
2022-01-10 13:22:28 +03:00
if ( ! g_setenv ( " OSTREE_SYSROOT_DEBUG " , buf - > str , TRUE ) )
return glnx_null_throw ( error , " Failed to set environment variable OSTREE_SYSROOT_DEBUG " ) ;
2016-05-13 20:22:02 +03:00
2023-05-01 21:24:29 +03:00
g_autoptr ( GFile ) sysroot_path = g_file_new_for_path ( " sysroot " ) ;
2017-09-13 19:09:51 +03:00
return ostree_sysroot_new ( sysroot_path ) ;
2016-03-02 18:05:08 +03:00
}