/* * Copyright (c) 2025 Matej Volf * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * - 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. * - The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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. */ #include <fibril.h> #include <posix/pthread.h> #include <pcut/pcut.h> PCUT_INIT; PCUT_TEST_SUITE(pthread_keys); pthread_key_t key; static errno_t simple_fibril(void *_arg) { PCUT_ASSERT_INT_EQUALS(0, pthread_setspecific(key, (void *) 0x0d9e)); PCUT_ASSERT_PTR_EQUALS((void *) 0x0d9e, pthread_getspecific(key)); for (int i = 0; i < 10; i++) { fibril_yield(); } return EOK; } PCUT_TEST(pthread_keys_basic) { PCUT_ASSERT_INT_EQUALS(0, pthread_key_create(&key, NULL)); PCUT_ASSERT_PTR_EQUALS(NULL, pthread_getspecific(key)); PCUT_ASSERT_INT_EQUALS(0, pthread_setspecific(key, (void *) 0x42)); PCUT_ASSERT_PTR_EQUALS((void *) 0x42, pthread_getspecific(key)); fid_t other = fibril_create(simple_fibril, NULL); fibril_start(other); for (int i = 0; i < 5; i++) { fibril_yield(); } PCUT_ASSERT_PTR_EQUALS((void *) 0x42, pthread_getspecific(key)); for (int i = 0; i < 10; i++) { fibril_yield(); } PCUT_ASSERT_PTR_EQUALS((void *) 0x42, pthread_getspecific(key)); } PCUT_EXPORT(pthread_keys);