diff --git a/concepts/booleans/about.md b/concepts/booleans/about.md
index e80148115..2d6fdde13 100644
--- a/concepts/booleans/about.md
+++ b/concepts/booleans/about.md
@@ -1,12 +1,68 @@
# About
-Booleans in Rust are represented by the `bool` type, which values can be either `true` or `false`.
+Booleans in Rust are represented by the `bool` type, with values either
+`true` or `false`.
-Rust supports one [boolean negation operator][negation operators]: `!` (Not).
+## Declaration
-Rust supports six [comparison operators][comparison operators]: `==` (Equal), `!=` (Not equal), `>` (Greater than), `<` (Less than), `>=`
-(Greater than or equal to), `<=` (Less than or equal to). They can be used to evaluate the relationship of non-boolean
-values into a boolean value.
+The Boolean type in Rust is specified using `bool`.
+
+```rust
+let t = true;
+
+let f: bool = false; // with explicit type annotation
+```
+
+The main way to use Boolean values is through conditionals, such as an if
+expression.
+
+### Use as a type
+Booleans can be used as a type for a variable, function parameter or return
+type.
+
+```rust
+let my_variable: bool;
+
+fn my_function(input: bool) -> bool {
+ // Do something
+}
+
+```
+
+### Operators
+
+Rust supports various operators on `bool` values.
+
+- AND (`&&`) operator computes the logical AND of its operands.
+ The result of `x && y` is `true` if both `x` and `y` evaluate to `true`.
+ Otherwise, the result is `false`.
+- OR (`||`) operator computes the logical OR of its operands.
+ The result of `x || y` is `true` if either `x` or `y` evaluates to `true`. Otherwise, the result is `false`.
+- NOT (`!`) operator computes logical negation of its operand.
+ That is, it produces `true`, if the operand evaluates to `false`, and `false`,
+ if the operand evaluates to `true`.
+
+The following example demonstrates the effect of each operator on bool values:
+
+```rust
+let x = true;
+let y = false;
+
+!x // => false
+
+x && y // => false
+
+x || y // => true
+
+```
+
+The [comparison operators][comparison operators] can be used to evaluate the relationship of non-boolean values into a boolean value.
+- `==` (Equal)
+- `!=` (Not equal)
+- `>` (Greater than)
+- `<` (Less than)
+- `>=` (Greater than or equal to)
+- `<=` (Less than or equal to).
```rust
1 > 0 // true
@@ -19,18 +75,43 @@ values into a boolean value.
Unlike some other languages, `0` is not `false` and non-zero is not `true`.
-Rust supports three [logical binary operators][logical binary operators]: `&` (Logical And), `|` (Logical Or), `^` (Logical Xor).
+Rust supports three [logical binary operators][logical binary operators]: `&`
+(Logical And), `|` (Logical Or), `^` (Logical Xor).
+
+- `|` (Logical Or)
+ | `a` | `b` | `a \| b` |
+ |- | - | - |
+ | `true` | `true` | `true` |
+ | `true` | `false` | `true` |
+ | `false` | `true` | `true` |
+ | `false` | `false` | `false` |
+
+- `&` (Logical And)
+ | `a` | `b` | [`a & b` |
+ |- | - | - |
+ | `true` | `true` | `true` |
+ | `true` | `false` | `false` |
+ | `false` | `true` | `false` |
+ | `false` | `false` | `false` |
+
+- `^` (Logical Xor)
+ | `a` | `b` | `a ^ b` |
+ |- | - | - |
+ | `true` | `true` | `false` |
+ | `true` | `false` | `true` |
+ | `false` | `true` | `true` |
+ | `false` | `false` | `false` |
-Rust supports two [boolean operators][lazy boolean operators]: `||` (Or), `&&` (And). They differ from `|` and `&` in that the right-hand operand
-is only evaluated when the left-hand operand does not already determine the result of the expression. That is, `||` only evaluates
-its right-hand operand when the left-hand operand evaluates to `false`, and `&&` only when it evaluates to `true`.
+The operators `||` (OR), `&&` (AND) differ from `|` and `&`.
+The `||` only evaluates its right-hand operand when the left-hand operand
+evaluates to `false`, and `&&` only when it evaluates to `true`.
+They are also called [lazy boolean operators] for this reason.
```rust
true || false // == true; the right-hand side was not evaluated
true && false // == false
```
-[negation operators]: https://doc.rust-lang.org/reference/expressions/operator-expr.html#negation-operators
[comparison operators]: https://doc.rust-lang.org/reference/expressions/operator-expr.html#comparison-operators
[logical binary operators]: https://doc.rust-lang.org/reference/expressions/operator-expr.html#arithmetic-and-logical-binary-operators
[lazy boolean operators]: https://doc.rust-lang.org/reference/expressions/operator-expr.html#lazy-boolean-operators
diff --git a/concepts/booleans/introduction.md b/concepts/booleans/introduction.md
index db0031ce9..07ca5fa97 100644
--- a/concepts/booleans/introduction.md
+++ b/concepts/booleans/introduction.md
@@ -1,22 +1,55 @@
# Introduction
-Booleans in Rust are represented by the `bool` type, which values can be either `true` or `false`.
+## Booleans
-Rust supports six comparison operators: `==` (Equal), `!=` (Not equal), `>` (Greater than), `<` (Less than), `>=`
-(Greater than or equal to), `<=` (Less than or equal to). They can be used to evaluate the relationship of non-boolean
-values into a boolean value.
+As in most other programming languages, a Boolean type in Rust has two possible values: `true` and `false`.
+
+### Declaration
+The Boolean type in Rust is specified using `bool`.
+
+```rust
+let t = true;
+
+let f: bool = false; // with explicit type annotation
+```
+
+The main way to use Boolean values is through conditionals, such as an if
+expression.
+We’ll cover how if expressions work in Rust in later concepts.
+
+### Use as a type
+Booleans can be used as a type for a variable, function parameter or return
+type.
```rust
-1 > 0 // true
-1 < 0 // false
-1 == 0 // false
-1 != 0 // true
-1 >= 0 // true
-1 <= 0 // false
+let my_variable: bool;
+
+fn my_function(input: bool) -> bool {
+ // Do something
+}
+
```
-Unlike some other languages, `0` is not `false` and non-zero is not `true`.
+### Basic Operators
+Rust supports following operators on `bool`:
+- AND (`&&`) operator computes the logical AND of its operands.
+ The result of `x && y` is `true` if both `x` and `y` evaluate to `true`.
+ Otherwise, the result is `false`.
+- OR (`||`) operator computes the logical OR of its operands.
+ The result of `x || y` is `true` if either `x` or `y` evaluates to `true`. Otherwise, the result is `false`.
+- NOT (`!`) operator computes logical negation of its operand.
+ That is, it produces `true`, if the operand evaluates to `false`, and `false`, if the operand evaluates to `true`.
+
+The following example demonstrates the effect of each operator on bool values:
+
+```rust
+let x = true;
+let y = false;
+
+!x // => false
+
+x && y // => false
-Rust supports two boolean operators: `||` (Or), `&&` (And). They are only evaluated when the left-hand operand does not already
-determine the result of the expression. That is, `||` only evaluates its right-hand operand when the left-hand operand evaluates
-to `false`, and `&&` only when it evaluates to `true`.
+x || y // => true
+
+```
diff --git a/config.json b/config.json
index 3ad25420c..27be6912f 100644
--- a/config.json
+++ b/config.json
@@ -35,6 +35,17 @@
},
"exercises": {
"concept": [
+ {
+ "slug": "annalyns-infiltration",
+ "name": "Annalyn's Infiltration",
+ "uuid": "897fa2ea-c29c-4d4e-9469-ff661a9b838a",
+ "difficulty": 1,
+ "concepts": [
+ "booleans"
+ ],
+ "prerequisites": [],
+ "status": "wip"
+ },
{
"slug": "lucians-luscious-lasagna",
"uuid": "29a2d3bd-eec8-454d-9dba-4b2d7d071925",
diff --git a/exercises/concept/annalyns-infiltration/.docs/hints.md b/exercises/concept/annalyns-infiltration/.docs/hints.md
new file mode 100644
index 000000000..9bb55aa8d
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/.docs/hints.md
@@ -0,0 +1,13 @@
+# Hints
+
+## General
+
+- There are three boolean operators[1] [2] to work with boolean values.
+- Multiple operators can be combined in a single expression.
+
+## 2. Check if a fast attack can be made
+
+- The boolean operators[1] [2] can also be applied to boolean parameters.
+
+[1]: https://doc.rust-lang.org/reference/expressions/operator-expr.html#lazy-boolean-operators
+[2]: https://doc.rust-lang.org/reference/expressions/operator-expr.html#negation-operators
diff --git a/exercises/concept/annalyns-infiltration/.docs/instructions.md b/exercises/concept/annalyns-infiltration/.docs/instructions.md
new file mode 100644
index 000000000..ab9c6fac5
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/.docs/instructions.md
@@ -0,0 +1,69 @@
+# Instructions
+
+In this exercise, you'll be implementing the quest logic for a new RPG game a friend is developing.
+
+The game's main character is Annalyn, a brave girl with a fierce and loyal pet dog. Unfortunately, disaster strikes, as her best friend was kidnapped while searching for berries in the forest.
+
+Annalyn will try to find and free her best friend, optionally taking her dog with her on this quest.
+
+After some time spent following her best friend's trail, she finds the camp in which her best friend is imprisoned. It turns out there are two kidnappers: a mighty knight and a cunning archer.
+
+Having found the kidnappers, Annalyn considers which of the following actions she can engage in:
+
+- _Fast attack_: a fast attack can be made if the knight is sleeping, as it takes time for him to get his armor on, so he will be vulnerable.
+- _Spy_: the group can be spied upon if at least one of them is awake. Otherwise, spying is a waste of time.
+- _Signal prisoner_: the prisoner can be signalled using bird sounds if the prisoner is awake and the archer is sleeping, as archers are trained in bird signaling so they could intercept the message.
+- _Free prisoner_: Annalyn can try sneaking into the camp to free the prisoner.
+ This is a risky thing to do and can only succeed in one of two ways:
+ - If Annalyn has her pet dog with her she can rescue the prisoner if the archer is asleep.
+ The knight is scared of the dog and the archer will not have time to get ready before Annalyn and the prisoner can escape.
+ - If Annalyn does not have her dog then she and the prisoner must be very sneaky!
+ Annalyn can free the prisoner if the prisoner is awake and the knight and archer are both sleeping, but if the prisoner is sleeping they can't be rescued: the prisoner would be startled by Annalyn's sudden appearance and wake up the knight and archer.
+
+You have four tasks: to implement the logic for determining if the above actions are available based on the state of the three characters found in the forest and whether Annalyn's pet dog is present or not.
+
+## 1. Check if a fast attack can be made
+
+Implement the `can_fast_attack()` function that takes a boolean value that indicates if the knight is awake. This function returns `true` if a fast attack can be made based on the state of the knight. Otherwise, returns `false`:
+
+```rust
+let knight_is_awake = true;
+can_fast_attack(knight_is_awake);
+// => false
+```
+
+## 2. Check if the group can be spied upon
+
+Implement the `can_spy()` function that takes three boolean values, indicating if the knight, archer and the prisoner, respectively, are awake. The function returns `true` if the group can be spied upon, based on the state of the three characters. Otherwise, returns `false`:
+
+```rust
+let knight_is_awake = false;
+let archer_is_awake = true;
+let prisoner_is_awake = false;
+can_spy(knight_is_awake, archer_is_awake, prisoner_is_awake);
+// => true
+```
+
+## 3. Check if the prisoner can be signalled
+
+Implement the `can_signal_prisoner()` function that takes two boolean values, indicating if the archer and the prisoner, respectively, are awake. The function returns `true` if the prisoner can be signalled, based on the state of the two characters. Otherwise, returns `false`:
+
+```rust
+let archer_is_awake = false;
+let prisoner_is_awake = true;
+can_signal_prisoner(archer_is_awake, prisoner_is_awake);
+// => true
+```
+
+## 4. Check if the prisoner can be freed
+
+Implement the `can_free_prisoner()` function that takes four boolean values. The first three parameters indicate if the knight, archer and the prisoner, respectively, are awake. The last parameter indicates if Annalyn's pet dog is present. The function returns `true` if the prisoner can be freed based on the state of the three characters and Annalyn's pet dog presence. Otherwise, it returns `false`:
+
+```rust
+let knight_is_awake = false;
+let archer_is_awake = true;
+let prisoner_is_awake = false;
+let pet_dog_is_present = false;
+can_free_prisoner(knight_is_awake, archer_is_awake, prisoner_is_awake, pet_dog_is_present);
+// => false
+```
diff --git a/exercises/concept/annalyns-infiltration/.docs/introduction.md b/exercises/concept/annalyns-infiltration/.docs/introduction.md
new file mode 100644
index 000000000..dedd7e7a7
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/.docs/introduction.md
@@ -0,0 +1,56 @@
+# Introduction
+
+## Booleans
+
+As in most other programming languages, a Boolean type in Rust has two possible values: `true` and `false`.
+
+### Declaration
+The Boolean type in Rust is specified using `bool`.
+
+```rust
+let t = true;
+
+let f: bool = false; // with explicit type annotation
+```
+
+The main way to use Boolean values is through conditionals, such as an if
+expression.
+We’ll cover how if expressions work in Rust in later concepts.
+
+### Use as a type
+Booleans can be used as a type for a variable, function parameter or return
+type.
+
+```rust
+let my_variable: bool;
+
+fn my_function(input: bool) -> bool {
+ // Do something
+}
+
+```
+
+### Basic Operators
+Rust supports following operators on `bool`:
+- AND (`&&`) operator computes the logical AND of its operands.
+ The result of `x && y` is `true` if both `x` and `y` evaluate to `true`.
+ Otherwise, the result is `false`.
+- OR (`||`) operator computes the logical OR of its operands.
+ The result of `x || y` is `true` if either `x` or `y` evaluates to `true`.
+ Otherwise, the result is `false`.
+- NOT (`!`) operator computes logical negation of its operand.
+ That is, it produces `true`, if the operand evaluates to `false`, and `false`, if the operand evaluates to `true`.
+
+The following example demonstrates the effect of each operator on bool values:
+
+```rust
+let x = true;
+let y = false;
+
+!x // => false
+
+x && y // => false
+
+x || y // => true
+
+```
diff --git a/exercises/concept/annalyns-infiltration/.gitignore b/exercises/concept/annalyns-infiltration/.gitignore
new file mode 100644
index 000000000..db7f315c0
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/.gitignore
@@ -0,0 +1,8 @@
+# Generated by Cargo
+# will have compiled files and executables
+/target/
+**/*.rs.bk
+
+# Remove Cargo.lock from gitignore if creating an executable, leave it for libraries
+# More information here http://doc.crates.io/guide.html#cargotoml-vs-cargolock
+Cargo.lock
diff --git a/exercises/concept/annalyns-infiltration/.meta/config.json b/exercises/concept/annalyns-infiltration/.meta/config.json
new file mode 100644
index 000000000..efd69e570
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/.meta/config.json
@@ -0,0 +1,22 @@
+{
+ "forked_from": [
+ "fsharp/annalyns-infiltration"
+ ],
+ "blurb": "Learn about booleans while helping Annalyn rescue her friend.",
+ "authors": [
+ "devkabiir"
+ ],
+ "contributors": [],
+ "files": {
+ "solution": [
+ "src/lib.rs",
+ "Cargo.toml"
+ ],
+ "test": [
+ "tests/annalyns-infiltration.rs"
+ ],
+ "exemplar": [
+ ".meta/exemplar.rs"
+ ]
+ }
+}
diff --git a/exercises/concept/annalyns-infiltration/.meta/design.md b/exercises/concept/annalyns-infiltration/.meta/design.md
new file mode 100644
index 000000000..22419dca1
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/.meta/design.md
@@ -0,0 +1,21 @@
+# Design
+
+## Learning objectives
+
+- Know of the existence of the `bool` type and its two values.
+- Know about boolean operators and how to build logical expressions with them.
+- Know of the boolean operator precedence rules.
+
+## Out of scope
+
+- Pattern matching on booleans.
+
+## Concepts
+
+- `booleans`: know of the existence of the `bool` type and its two values; know about boolean operators and how to build logical expressions with them; know of the boolean operator precedence rules.
+
+## Prerequisites
+
+This exercise's prerequisites Concepts are:
+
+- none
diff --git a/exercises/concept/annalyns-infiltration/.meta/exemplar.rs b/exercises/concept/annalyns-infiltration/.meta/exemplar.rs
new file mode 100644
index 000000000..207556c83
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/.meta/exemplar.rs
@@ -0,0 +1,21 @@
+pub fn can_fast_attack(knight_is_awake: bool) -> bool {
+ !knight_is_awake
+}
+
+pub fn can_spy(knight_is_awake: bool, archer_is_awake: bool, prisoner_is_awake: bool) -> bool {
+ knight_is_awake || archer_is_awake || prisoner_is_awake
+}
+
+pub fn can_signal_prisoner(archer_is_awake: bool, prisoner_is_awake: bool) -> bool {
+ !archer_is_awake && prisoner_is_awake
+}
+
+pub fn can_free_prisoner(
+ knight_is_awake: bool,
+ archer_is_awake: bool,
+ prisoner_is_awake: bool,
+ pet_dog_is_present: bool,
+) -> bool {
+ !knight_is_awake && !archer_is_awake && prisoner_is_awake
+ || !archer_is_awake && pet_dog_is_present
+}
diff --git a/exercises/concept/annalyns-infiltration/Cargo.toml b/exercises/concept/annalyns-infiltration/Cargo.toml
new file mode 100644
index 000000000..1abcea86c
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/Cargo.toml
@@ -0,0 +1,4 @@
+[package]
+edition = "2021"
+name = "annalyns_infiltration"
+version = "1.0.0"
diff --git a/exercises/concept/annalyns-infiltration/src/lib.rs b/exercises/concept/annalyns-infiltration/src/lib.rs
new file mode 100644
index 000000000..ec229dc4f
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/src/lib.rs
@@ -0,0 +1,20 @@
+pub fn can_fast_attack(_knight_is_awake: bool) -> bool {
+ unimplemented!("Implement can_fast_attack");
+}
+
+pub fn can_spy(_knight_is_awake: bool, _archer_is_awake: bool, _prisoner_is_awake: bool) -> bool {
+ unimplemented!("Implement can_spy");
+}
+
+pub fn can_signal_prisoner(_archer_is_awake: bool, _prisoner_is_awake: bool) -> bool {
+ unimplemented!("Implement can_signal_prisoner");
+}
+
+pub fn can_free_prisoner(
+ _knight_is_awake: bool,
+ _archer_is_awake: bool,
+ _prisoner_is_awake: bool,
+ _pet_dog_is_present: bool,
+) -> bool {
+ unimplemented!("Implement can_free_prisoner");
+}
diff --git a/exercises/concept/annalyns-infiltration/tests/annalyns-infiltration.rs b/exercises/concept/annalyns-infiltration/tests/annalyns-infiltration.rs
new file mode 100644
index 000000000..93d139da2
--- /dev/null
+++ b/exercises/concept/annalyns-infiltration/tests/annalyns-infiltration.rs
@@ -0,0 +1,401 @@
+#[test]
+fn cannot_execute_fast_attack_if_knight_is_awake() {
+ let knight_is_awake = true;
+ assert!(!annalyns_infiltration::can_fast_attack(knight_is_awake));
+}
+
+#[test]
+#[ignore]
+fn can_execute_fast_attack_if_knight_is_sleeping() {
+ let knight_is_awake = false;
+ assert!(annalyns_infiltration::can_fast_attack(knight_is_awake));
+}
+
+#[test]
+#[ignore]
+fn cannot_spy_if_everyone_is_sleeping() {
+ let knight_is_awake = false;
+ let archer_is_awake = false;
+ let prisoner_is_awake = false;
+ assert!(!annalyns_infiltration::can_spy(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_spy_if_everyone_but_knight_is_sleeping() {
+ let knight_is_awake = true;
+ let archer_is_awake = false;
+ let prisoner_is_awake = false;
+ assert!(annalyns_infiltration::can_spy(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_spy_if_everyone_but_archer_is_sleeping() {
+ let knight_is_awake = false;
+ let archer_is_awake = true;
+ let prisoner_is_awake = false;
+ assert!(annalyns_infiltration::can_spy(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_spy_if_everyone_but_prisoner_is_sleeping() {
+ let knight_is_awake = false;
+ let archer_is_awake = false;
+
+ let prisoner_is_awake = true;
+ assert!(annalyns_infiltration::can_spy(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_spy_if_only_knight_is_sleeping() {
+ let knight_is_awake = false;
+ let archer_is_awake = true;
+ let prisoner_is_awake = true;
+ assert!(annalyns_infiltration::can_spy(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_spy_if_only_archer_is_sleeping() {
+ let knight_is_awake = true;
+ let archer_is_awake = false;
+ let prisoner_is_awake = true;
+ assert!(annalyns_infiltration::can_spy(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_spy_if_only_prisoner_is_sleeping() {
+ let knight_is_awake = true;
+ let archer_is_awake = true;
+ let prisoner_is_awake = false;
+ assert!(annalyns_infiltration::can_spy(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_spy_if_everyone_is_awake() {
+ let knight_is_awake = true;
+ let archer_is_awake = true;
+ let prisoner_is_awake = true;
+ assert!(annalyns_infiltration::can_spy(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_signal_prisoner_if_archer_is_sleeping_and_prisoner_is_awake() {
+ let archer_is_awake = false;
+ let prisoner_is_awake = true;
+ assert!(annalyns_infiltration::can_signal_prisoner(
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_signal_prisoner_if_archer_is_awake_and_prisoner_is_sleeping() {
+ let archer_is_awake = true;
+ let prisoner_is_awake = false;
+ assert!(!annalyns_infiltration::can_signal_prisoner(
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_signal_prisoner_if_archer_and_prisoner_are_both_sleeping() {
+ let archer_is_awake = false;
+ let prisoner_is_awake = false;
+ assert!(!annalyns_infiltration::can_signal_prisoner(
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_signal_prisoner_if_archer_and_prisoner_are_both_awake() {
+ let archer_is_awake = true;
+ let prisoner_is_awake = true;
+ assert!(!annalyns_infiltration::can_signal_prisoner(
+ archer_is_awake,
+ prisoner_is_awake
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_everyone_is_awake_and_pet_dog_is_present() {
+ let knight_is_awake = true;
+ let archer_is_awake = true;
+ let prisoner_is_awake = true;
+ let pet_dog_is_present = true;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_everyone_is_awake_and_pet_dog_is_absent() {
+ let knight_is_awake = true;
+ let archer_is_awake = true;
+ let prisoner_is_awake = true;
+ let pet_dog_is_present = false;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_free_prisoner_if_everyone_is_asleep_and_pet_dog_is_present() {
+ let knight_is_awake = false;
+ let archer_is_awake = false;
+ let prisoner_is_awake = false;
+ let pet_dog_is_present = true;
+ assert!(annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_everyone_is_asleep_and_pet_dog_is_absent() {
+ let knight_is_awake = false;
+ let archer_is_awake = false;
+ let prisoner_is_awake = false;
+ let pet_dog_is_present = false;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_free_prisoner_if_only_prisoner_is_awake_and_pet_dog_is_present() {
+ let knight_is_awake = false;
+ let archer_is_awake = false;
+ let prisoner_is_awake = true;
+ let pet_dog_is_present = true;
+ assert!(annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_free_prisoner_if_only_prisoner_is_awake_and_pet_dog_is_absent() {
+ let knight_is_awake = false;
+ let archer_is_awake = false;
+ let prisoner_is_awake = true;
+ let pet_dog_is_present = false;
+ assert!(annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_only_archer_is_awake_and_pet_dog_is_present() {
+ let knight_is_awake = false;
+ let archer_is_awake = true;
+ let prisoner_is_awake = false;
+ let pet_dog_is_present = true;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_only_archer_is_awake_and_pet_dog_is_absent() {
+ let knight_is_awake = false;
+ let archer_is_awake = true;
+ let prisoner_is_awake = false;
+ let pet_dog_is_present = false;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_free_prisoner_if_only_knight_is_awake_and_pet_dog_is_present() {
+ let knight_is_awake = true;
+ let archer_is_awake = false;
+ let prisoner_is_awake = false;
+ let pet_dog_is_present = true;
+ assert!(annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_only_knight_is_awake_and_pet_dog_is_absent() {
+ let knight_is_awake = true;
+ let archer_is_awake = false;
+ let prisoner_is_awake = false;
+ let pet_dog_is_present = false;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_only_knight_is_asleep_and_pet_dog_is_present() {
+ let knight_is_awake = false;
+ let archer_is_awake = true;
+ let prisoner_is_awake = true;
+ let pet_dog_is_present = true;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_only_knight_is_asleep_and_pet_dog_is_absent() {
+ let knight_is_awake = false;
+ let archer_is_awake = true;
+ let prisoner_is_awake = true;
+ let pet_dog_is_present = false;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn can_free_prisoner_if_only_archer_is_asleep_and_pet_dog_is_present() {
+ let knight_is_awake = true;
+ let archer_is_awake = false;
+ let prisoner_is_awake = true;
+ let pet_dog_is_present = true;
+ assert!(annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_only_archer_is_asleep_and_pet_dog_is_absent() {
+ let knight_is_awake = true;
+ let archer_is_awake = false;
+ let prisoner_is_awake = true;
+ let pet_dog_is_present = false;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_only_prisoner_is_asleep_and_pet_dog_is_present() {
+ let knight_is_awake = true;
+ let archer_is_awake = true;
+ let prisoner_is_awake = false;
+ let pet_dog_is_present = true;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}
+
+#[test]
+#[ignore]
+fn cannot_free_prisoner_if_only_prisoner_is_asleep_and_pet_dog_is_absent() {
+ let knight_is_awake = true;
+ let archer_is_awake = true;
+ let prisoner_is_awake = false;
+ let pet_dog_is_present = false;
+ assert!(!annalyns_infiltration::can_free_prisoner(
+ knight_is_awake,
+ archer_is_awake,
+ prisoner_is_awake,
+ pet_dog_is_present
+ ));
+}