summaryrefslogtreecommitdiffstats
path: root/third_party/rust/derive_more/tests/unwrap.rs
blob: dca8fc4c192c55804c837e675b859fb1f5f5b53b (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
115
116
117
118
119
#![cfg_attr(not(feature = "std"), no_std)]
#![allow(dead_code)]

use derive_more::Unwrap;

#[derive(Unwrap)]
enum Either<TLeft, TRight> {
    Left(TLeft),
    Right(TRight),
}

#[derive(Unwrap)]
#[derive(Debug)]
#[unwrap(ref, ref_mut)]
enum Maybe<T> {
    Nothing,
    Just(T),
}

#[derive(Unwrap)]
enum Color {
    RGB(u8, u8, u8),
    CMYK(u8, u8, u8, u8),
}

/// With lifetime
#[derive(Unwrap)]
enum Nonsense<'a, T> {
    Ref(&'a T),
    NoRef,
    #[unwrap(ignore)]
    NoRefIgnored,
}

#[derive(Unwrap)]
enum WithConstraints<T>
where
    T: Copy,
{
    One(T),
    Two,
}

#[derive(Unwrap)]
enum KitchenSink<'a, 'b, T1: Copy, T2: Clone>
where
    T2: Into<T1> + 'b,
{
    Left(&'a T1),
    Right(&'b T2),
    OwnBoth(T1, T2),
    Empty,
    NeverMind(),
    NothingToSeeHere(),
}

/// Single variant enum
#[derive(Unwrap)]
enum Single {
    Value(i32),
}

#[derive(Unwrap)]
#[derive(Debug, PartialEq)]
#[unwrap(ref, ref_mut)]
enum Tuple<T> {
    None,
    Single(T),
    Double(T, T),
    Triple(T, T, T),
}

#[test]
pub fn test_unwrap() {
    assert_eq!(Maybe::<()>::Nothing.unwrap_nothing(), ());
    assert_eq!(Maybe::Just(1).unwrap_just(), 1);

    assert_eq!((&Maybe::Just(42)).unwrap_just_ref(), &42);
    assert_eq!((&mut Maybe::Just(42)).unwrap_just_mut(), &mut 42);
}

#[test]
#[should_panic]
pub fn test_unwrap_panic_1() {
    Maybe::<()>::Nothing.unwrap_just();
}

#[test]
#[should_panic]
pub fn test_unwrap_panic_2() {
    Maybe::Just(2).unwrap_nothing();
}

#[test]
#[should_panic]
pub fn test_unwrap_ref_panic() {
    Maybe::Just(2).unwrap_nothing_ref();
}

#[test]
pub fn test_unwrap_mut_1() {
    let mut value = Tuple::Double(1, 12);

    let (a, b) = value.unwrap_double_mut();
    *a = 9;
    *b = 10;

    assert_eq!(value, Tuple::Double(9, 10))
}

#[test]
pub fn test_unwrap_mut_2() {
    let mut value = Tuple::Single(128);

    let x = value.unwrap_single_mut();
    *x *= 2;

    assert_eq!(value, Tuple::Single(256));
}