2017-09-21 15:26:06 -04:00
/*
2017-04-19 00:11:28 +01:00
* Copyright © 2017 Endless Mobile , Inc .
*
2018-01-30 20:26:26 +01:00
* SPDX - License - Identifier : LGPL - 2.0 +
*
2017-04-19 00:11:28 +01: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-06 20:20:55 -05:00
* License along with this library . If not , see < https : //www.gnu.org/licenses/>.
2017-04-19 00:11:28 +01:00
*
* Authors :
* - Philip Withnall < withnall @ endlessm . com >
*/
# include "config.h"
# include <gio/gio.h>
# include <glib.h>
# include "ostree-bloom-private.h"
/* Test the two different constructors work at a basic level. */
static void
test_bloom_init ( void )
{
2023-05-01 14:24:29 -04:00
g_autoptr ( OstreeBloom ) bloom = NULL ;
g_autoptr ( GBytes ) bytes = NULL ;
2017-04-19 00:11:28 +01:00
bloom = ostree_bloom_new ( 1 , 1 , ostree_str_bloom_hash ) ;
g_assert_cmpuint ( ostree_bloom_get_size ( bloom ) , = = , 1 ) ;
g_assert_cmpuint ( ostree_bloom_get_k ( bloom ) , = = , 1 ) ;
g_assert ( ostree_bloom_get_hash_func ( bloom ) = = ostree_str_bloom_hash ) ;
g_clear_pointer ( & bloom , ostree_bloom_unref ) ;
bytes = g_bytes_new_take ( g_malloc0 ( 4 ) , 4 ) ;
bloom = ostree_bloom_new_from_bytes ( bytes , 1 , ostree_str_bloom_hash ) ;
g_assert_cmpuint ( ostree_bloom_get_size ( bloom ) , = = , 4 ) ;
g_assert_cmpuint ( ostree_bloom_get_k ( bloom ) , = = , 1 ) ;
g_assert ( ostree_bloom_get_hash_func ( bloom ) = = ostree_str_bloom_hash ) ;
g_clear_pointer ( & bloom , ostree_bloom_unref ) ;
}
/* Test that building a bloom filter, marshalling it through GBytes, and loading
* it again , gives the same element membership . */
static void
test_bloom_construction ( void )
{
2023-05-01 14:24:29 -04:00
g_autoptr ( OstreeBloom ) bloom = NULL ;
g_autoptr ( OstreeBloom ) immutable_bloom = NULL ;
g_autoptr ( GBytes ) bytes = NULL ;
2017-04-19 00:11:28 +01:00
gsize i ;
2023-05-01 14:24:29 -04:00
const gchar * members [ ] = { " hello " , " there " , " these " , " are " , " test " , " strings " } ;
const gchar * non_members [ ] = { " not " , " an " , " element " } ;
2017-04-19 00:11:28 +01:00
const gsize n_bytes = 256 ;
const guint8 k = 8 ;
const OstreeBloomHashFunc hash = ostree_str_bloom_hash ;
/* Build a bloom filter. */
bloom = ostree_bloom_new ( n_bytes , k , hash ) ;
for ( i = 0 ; i < G_N_ELEMENTS ( members ) ; i + + )
ostree_bloom_add_element ( bloom , members [ i ] ) ;
bytes = ostree_bloom_seal ( bloom ) ;
/* Read it back from the GBytes. */
immutable_bloom = ostree_bloom_new_from_bytes ( bytes , k , hash ) ;
for ( i = 0 ; i < G_N_ELEMENTS ( members ) ; i + + )
g_assert_true ( ostree_bloom_maybe_contains ( bloom , members [ i ] ) ) ;
/* This should never fail in future, as we guarantee the hash function will
* never change . But given the definition of a bloom filter , it would also
* be valid for these calls to return % TRUE . */
for ( i = 0 ; i < G_N_ELEMENTS ( non_members ) ; i + + )
g_assert_false ( ostree_bloom_maybe_contains ( bloom , non_members [ i ] ) ) ;
}
/* Test that an empty bloom filter definitely contains no elements. */
static void
test_bloom_empty ( void )
{
2023-05-01 14:24:29 -04:00
g_autoptr ( OstreeBloom ) bloom = NULL ;
2017-04-19 00:11:28 +01:00
const gsize n_bytes = 256 ;
const guint8 k = 8 ;
const OstreeBloomHashFunc hash = ostree_str_bloom_hash ;
/* Build an empty bloom filter. */
bloom = ostree_bloom_new ( n_bytes , k , hash ) ;
g_assert_false ( ostree_bloom_maybe_contains ( bloom , " hello " ) ) ;
g_assert_false ( ostree_bloom_maybe_contains ( bloom , " there " ) ) ;
}
/* Build a bloom filter, and check the membership of the members as they are
* added . */
static void
test_bloom_membership_during_construction ( void )
{
2023-05-01 14:24:29 -04:00
g_autoptr ( OstreeBloom ) bloom = NULL ;
2017-04-19 00:11:28 +01:00
gsize i , j ;
2023-05-01 14:24:29 -04:00
const gchar * members [ ] = { " hello " , " there " , " these " , " are " , " test " , " strings " } ;
2017-04-19 00:11:28 +01:00
const gsize n_bytes = 256 ;
const guint8 k = 8 ;
const OstreeBloomHashFunc hash = ostree_str_bloom_hash ;
/* These membership checks should never fail in future, as we guarantee
* the hash function will never change . But given the definition of a bloom
* filter , it would also be valid for these checks to fail . */
bloom = ostree_bloom_new ( n_bytes , k , hash ) ;
for ( i = 0 ; i < G_N_ELEMENTS ( members ) ; i + + )
{
ostree_bloom_add_element ( bloom , members [ i ] ) ;
for ( j = 0 ; j < G_N_ELEMENTS ( members ) ; j + + )
{
if ( j < = i )
g_assert_true ( ostree_bloom_maybe_contains ( bloom , members [ j ] ) ) ;
else
g_assert_false ( ostree_bloom_maybe_contains ( bloom , members [ j ] ) ) ;
}
}
}
2023-05-01 14:24:29 -04:00
int
main ( int argc , char * * argv )
2017-04-19 00:11:28 +01:00
{
g_test_init ( & argc , & argv , NULL ) ;
g_test_add_func ( " /bloom/init " , test_bloom_init ) ;
g_test_add_func ( " /bloom/construction " , test_bloom_construction ) ;
g_test_add_func ( " /bloom/empty " , test_bloom_empty ) ;
2023-05-01 14:24:29 -04:00
g_test_add_func ( " /bloom/membership-during-construction " ,
test_bloom_membership_during_construction ) ;
2017-04-19 00:11:28 +01:00
2023-05-01 14:24:29 -04:00
return g_test_run ( ) ;
2017-04-19 00:11:28 +01:00
}