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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
|
use wasm_bindgen::prelude::*;
use wasm_bindgen_test::*;
use web_sys::HtmlSelectElement;
#[wasm_bindgen(module = "/tests/wasm/element.js")]
extern "C" {
fn new_select_with_food_opts() -> HtmlSelectElement;
}
#[wasm_bindgen_test]
fn test_select_element() {
// Creates a select with four options. Options are ["tomato", "potato", "orange", "apple"], where
// the string is the .value and .text of each option.
let select = new_select_with_food_opts();
select.set_autofocus(true);
assert_eq!(
select.autofocus(),
true,
"Select element should have a true autofocus property."
);
select.set_autofocus(false);
assert_eq!(
select.autofocus(),
false,
"Select element should have a false autofocus property."
);
// TODO: This test currently fails on Firefox, but not Chrome. In Firefox, even though we select.set_autocomplete(), select.autocomplete() yields an empty String.
// select.set_autocomplete("tomato");
// assert_eq!(select.autocomplete(), "tomato", "Select element should have a 'tomato' autocomplete property.");
select.set_disabled(true);
assert_eq!(
select.disabled(),
true,
"Select element should be disabled."
);
select.set_disabled(false);
assert_eq!(
select.disabled(),
false,
"Select element should not be disabled."
);
assert!(
select.form().is_none(),
"Select should not be associated with a form."
);
select.set_multiple(false);
assert_eq!(
select.multiple(),
false,
"Select element should have a false multiple property."
);
select.set_multiple(true);
assert_eq!(
select.multiple(),
true,
"Select element should have a true multiple property."
);
select.set_name("potato");
assert_eq!(
select.name(),
"potato",
"Select element should have a name property of 'potato'."
);
select.set_required(true);
assert_eq!(
select.required(),
true,
"Select element should be required."
);
select.set_required(false);
assert_eq!(
select.required(),
false,
"Select element should not be required."
);
select.set_size(432);
assert_eq!(
select.size(),
432,
"Select element should have a size property of 432."
);
// Default type seems to be "select-multiple" for the browsers I tested, but there's no guarantee
// on this, so let's just make sure we get back something here.
assert!(
select.type_().len() > 0,
"Select element should have some type."
);
assert!(
select.options().length() == 4,
"Select element should have four options."
);
select.set_length(12);
assert_eq!(
select.length(),
12,
"Select element should have a length of 12."
);
// Reset the length to four, as that's how many options we actually have.
select.set_length(4);
assert!(
select
.named_item("this should definitely find nothing")
.is_none(),
"Shouldn't be able to find a named item with the given string."
);
assert!(
select.selected_options().length() == 1,
"One option should be selected by default, just by way of having items."
);
select.set_selected_index(2);
assert_eq!(
select.selected_index(),
2,
"Select element should have a selected index of 2."
);
// Quote from docs: The value property sets or returns the value of the selected option in a drop-down list.
select.set_value("tomato"); // Select the "tomato" option
assert_eq!(
select.value(),
"tomato",
"Select element should have no selected value."
);
// This might be browser dependent, potentially rendering this test useless? Worked fine in Chrome and Firefox for now.
assert_eq!(
select.will_validate(),
true,
"Select element should not validate by default."
);
assert!(
select.validation_message().is_ok(),
"Select element should retrieve a validation message."
);
assert!(
select.validity().valid(),
"Our basic select should be valid."
);
assert!(
select.check_validity(),
"Our basic select should check out as valid."
);
assert!(
select.report_validity(),
"Our basic select should report valid."
);
select.set_custom_validity("Some custom validity error.");
assert!(
select.labels().length() == 0,
"There should be no labels associated with our select element."
);
// TODO: This test won't work until this bug is fixed: https://www.w3.org/Bugs/Public/show_bug.cgi?id=20720. Sometime in the future, either remove this test or uncomment after bug is fixed.
// assert!(select.named_item("tomato").is_some(), "Should be able to find the 'tomato' option before removing it.");
// select.remove(0);
// assert!(select.named_item("tomato").is_none(), "Shouldn't be able to find the 'tomato' option after removing it.")
// TODO: As a result, we are missing a test for the remove() method.
}
|