Normal Assertions
Learn how to use normal assertion methods in BELLATRIX tests.
Example
[Test]
public void CommonAssertionsIOSControls()
{
var button = App.Components.CreateByName<Button>("ComputeSumButton");
button.Click();
Assert.AreEqual(false, button.IsDisabled);
var answerLabel = App.Components.CreateByName<Label>("Answer");
Assert.IsTrue(answerLabel.IsPresent);
var password = App.Components.CreateById<Password>("IntegerB");
password.SetPassword("9");
var textField = App.Components.CreateById<TextField>("IntegerA");
textField.SetText("1");
Assert.AreEqual("1", textField.GetText());
var checkBox = App.Components.CreateByIOSNsPredicate<CheckBox>(
"type == \"XCUIElementTypeSwitch\" AND name == \"All-day\"");
checkBox.Check();
Assert.IsTrue(checkBox.IsChecked);
checkBox.Uncheck();
Assert.IsFalse(checkBox.IsChecked);
var radioButton = App.Components.CreateByIOSNsPredicate<RadioButton>(
"type == \"XCUIElementTypeSwitch\" AND name == \"All-day\"");
radioButton.Click();
Assert.IsTrue(radioButton.IsChecked);
Bellatrix.Assertions.Assert.Multiple(
() => Assert.IsTrue(radioButton.IsChecked),
() => Assert.IsFalse(!radioButton.IsChecked));
}
Explanations
Assert.AreEqual(false, button.IsDisabled);
We can assert whether the control is disabled. The different BELLATRIX iOS elements classes contain lots of these properties which are a representation of the most important app element attributes. The biggest drawback of using vanilla assertions is that the messages displayed on failure are not meaningful at all. This is so because most unit testing frameworks are created for much simpler and shorter unit tests. In next chapter, there is information how BELLATRIX solves the problems with the introduction of Ensure methods. If the bellow assertion fails the following message is displayed: “*Message: Assert.AreEqual failed. Expected:
Assert.IsTrue(checkBox.IsChecked);
Asserts that the checkbox is checked. On fail the following message is displayed: “Message: Assert.IsTrue failed.” Cannot learn much about what happened.
Assert.AreEqual("1", textField.GetText());
Assert the correct text is set.
Assert.IsTrue(answerLabel.IsPresent);
See if the element is present or not using the IsPresent property.
Assert.IsTrue(radioButton.IsChecked);
Assert that the radio button is clicked.
Bellatrix.Assertions.Assert.Multiple(
() => Assert.IsTrue(radioButton.IsChecked),
() => Assert.IsFalse(!radioButton.IsChecked));
You can execute multiple assertions failing only once viewing all results.
One more thing you need to keep in mind is that normal assertion methods do not include BDD logging and any available hooks. BELLATRIX provides you with a full BDD logging support for ensure assertions and gives you a way to hook your logic in multiple places.