summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/assert/test/assert_msg_test2.cpp
blob: 9d8f8da3d86a1f4f4127e8b4f95964474fc97a4f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
//
//  assert_msg_test2.cpp - a test for BOOST_ASSERT_MSG and NDEBUG
//
//  Copyright (c) 2014 Peter Dimov
//
//  Distributed under the Boost Software License, Version 1.0.
//  See accompanying file LICENSE_1_0.txt or copy at
//  http://www.boost.org/LICENSE_1_0.txt
//

#include <boost/detail/lightweight_test.hpp>
#include <stdio.h>

// default case, !NDEBUG
// BOOST_ASSERT_MSG(x) -> assert(x)

#undef NDEBUG
#include <boost/assert.hpp>

void test_default()
{
    int x = 1;

    BOOST_ASSERT_MSG( 1, "msg" );
    BOOST_ASSERT_MSG( x, "msg" );
    BOOST_ASSERT_MSG( x == 1, "msg" );
}

// default case, NDEBUG
// BOOST_ASSERT_MSG(x) -> assert(x)

#define NDEBUG
#include <boost/assert.hpp>

void test_default_ndebug()
{
    int x = 1;

    BOOST_ASSERT_MSG( 1, "msg" );
    BOOST_ASSERT_MSG( x, "msg" );
    BOOST_ASSERT_MSG( x == 1, "msg" );

    BOOST_ASSERT_MSG( 0, "msg" );
    BOOST_ASSERT_MSG( !x, "msg" );
    BOOST_ASSERT_MSG( x == 0, "msg" );
}

// BOOST_ENABLE_ASSERT_DEBUG_HANDLER, !NDEBUG
// same as BOOST_ENABLE_ASSERT_HANDLER

#define BOOST_ENABLE_ASSERT_DEBUG_HANDLER

#undef NDEBUG
#include <boost/assert.hpp>

int handler_invoked = 0;

void boost::assertion_failed_msg( char const * expr, char const * msg, char const * function, char const * file, long line )
{
    printf( "Expression: %s\nMessage: %s\nFunction: %s\nFile: %s\nLine: %ld\n\n", expr, msg, function, file, line );
    ++handler_invoked;
}

void test_debug_handler()
{
    handler_invoked = 0;

    int x = 1;

    BOOST_ASSERT_MSG( 1, "msg" );
    BOOST_ASSERT_MSG( x, "msg" );
    BOOST_ASSERT_MSG( x == 1, "msg" );

    BOOST_ASSERT_MSG( 0, "msg" );
    BOOST_ASSERT_MSG( !x, "msg" );
    BOOST_ASSERT_MSG( x == 0, "msg" );

    BOOST_TEST( handler_invoked == 3 );
}

// BOOST_ENABLE_ASSERT_DEBUG_HANDLER, NDEBUG
// BOOST_ASSERT_MSG(x) -> ((void)0)

#define NDEBUG
#include <boost/assert.hpp>

void test_debug_handler_ndebug()
{
    handler_invoked = 0;

    int x = 1;

    BOOST_ASSERT_MSG( 1, "msg" );
    BOOST_ASSERT_MSG( x, "msg" );
    BOOST_ASSERT_MSG( x == 1, "msg" );

    BOOST_ASSERT_MSG( 0, "msg" );
    BOOST_ASSERT_MSG( !x, "msg" );
    BOOST_ASSERT_MSG( x == 0, "msg" );

    BOOST_TEST( handler_invoked == 0 );
}

#undef BOOST_ENABLE_ASSERT_DEBUG_HANDLER

int main()
{
    test_default();
    test_default_ndebug();
    test_debug_handler();
    test_debug_handler_ndebug();

    return boost::report_errors();
}