/*
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * Copyright 2015 Danny Robson <danny@nerdcruft.net>
 */

#include "memory/buffer/circular.hpp"
#include "tap.hpp"

#include <algorithm>

///////////////////////////////////////////////////////////////////////////////
int
main (void)
{
    cruft::TAP::logger tap;

    // provoke usage of the smallest size buffer we can get away with so we
    // might detect caching issues or similar.
    constexpr size_t CAPACITY = 1;
    cruft::memory::buffer::circular buffer (CAPACITY);

    // zero fill to ensure our value setting tests don't accidentall succeed
    std::fill_n (buffer.begin (), buffer.size () * 2, 0);

    // sanity check we haven't accidentally mapped an empty region
    tap.expect_neq (buffer.begin (), buffer.end (), "non-zero sized region");

    // check a near overrun is replicated
    buffer.end ()[0] = 1;
    tap.expect_eq (buffer.begin ()[0], buffer.end ()[0], "near overrun is replicated");

    // check a far overrun is replicated
    buffer.end ()[buffer.size () - 1] = 2;
    tap.expect_eq (buffer.begin ()[buffer.size () - 1],
                   buffer.end   ()[buffer.size () - 1],
                   "far overrun is replicated");

    return tap.status ();
}