647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek/***
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek This file is part of systemd
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek Copyright 2014 Zbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek systemd is free software; you can redistribute it and/or modify it
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek under the terms of the GNU Lesser General Public License as published by
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek the Free Software Foundation; either version 2.1 of the License, or
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek (at your option) any later version.
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek systemd is distributed in the hope that it will be useful, but
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek WITHOUT ANY WARRANTY; without even the implied warranty of
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek Lesser General Public License for more details.
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek You should have received a copy of the GNU Lesser General Public License
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek along with systemd; If not, see <http://www.gnu.org/licenses/>.
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek***/
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek#include "set.h"
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmekstatic void test_set_steal_first(void) {
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek _cleanup_set_free_ Set *m = NULL;
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek int seen[3] = {};
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek char *val;
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek m = set_new(&string_hash_ops);
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek assert_se(m);
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek assert_se(set_put(m, (void*) "1") == 1);
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek assert_se(set_put(m, (void*) "22") == 1);
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek assert_se(set_put(m, (void*) "333") == 1);
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek while ((val = set_steal_first(m)))
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek seen[strlen(val) - 1]++;
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
bdf7026e9557349cd3eeb291c01655d5f2a55db8Thomas Hindoe Paaboel Andersen assert_se(seen[0] == 1 && seen[1] == 1 && seen[2] == 1);
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek assert_se(set_isempty(m));
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek}
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalierstatic void test_set_put(void) {
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier _cleanup_set_free_ Set *m = NULL;
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier m = set_new(&string_hash_ops);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(m);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(set_put(m, (void*) "1") == 1);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(set_put(m, (void*) "22") == 1);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(set_put(m, (void*) "333") == 1);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(set_put(m, (void*) "333") == 0);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(set_remove(m, (void*) "333"));
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(set_put(m, (void*) "333") == 1);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(set_put(m, (void*) "333") == 0);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier assert_se(set_put(m, (void*) "22") == 0);
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier}
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmekint main(int argc, const char *argv[]) {
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek test_set_steal_first();
756c09e672a08efd9e728a5cab50a641b022b84cRonny Chevalier test_set_put();
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek return 0;
647f68249f90855814de6eb6b0959c6096b41caeZbigniew Jędrzejewski-Szmek}