Читаем Rust на примерах полностью

} else {

write!(f, "{}+{}i", self.re, self.im)

}

}

}

<p id="Тестирование_1"><strong><a l:href="#Тестирование_1">Тестирование</a></strong></p>

Rust - это язык программирования, который очень заботится о корректности и включает в себя поддержку написания тестов программного обеспечения в самом языке.

Тестирование поставляется в трёх стилях:

   • Модульное тестирование.

   • Тестирование кода из примеров документации.

   • Интеграционное тестирование.

Также Rust поддерживает указание дополнительных зависимостей для тестов:

   • Dev-dependencies

<p id="Смотрите_также_70"><strong><a l:href="#Смотрите_также_70">Смотрите также:</a></strong></p>

   • Глава о тестировании в "The Rust Programming Language"

   • Описание API для тестирования примеров из документации.

<p id="unit_тестирование"><strong><a l:href="#unit_тестирование">Unit-тестирование</a></strong></p>

Тесты - это функции на Rust, которые проверяют, что тестируемый код работает ожидаемым образом. Тело тестовых функций обычно выполняет некоторую настройку, запускает код, который мы тестируем, и затем сравнивает полученный результат с тем, что мы ожидаем.

Большинство модульных тестов располагается в модуле tests, помеченном атрибутом #[cfg(test)]. Тестовые функции помечаются атрибутом #[test].

Тесты заканчиваются неудачей, когда что-либо в тестовой функции вызывает панику. Есть несколько вспомогательных макросов:

   • assert!(expression) - паникует, если результат выражения равен false.

   • assert_eq!(left, right) и assert_ne!(left, right) - сравнивает левое и правое выражения на равенство и неравенство соответственно.

pub fn add(a: i32, b: i32) -> i32 {

a + b

}

// Это действительно плохая функция сложения, её назначение в данном // примере - потерпеть неудачу.

#[allow(dead_code)]

fn bad_add(a: i32, b: i32) -> i32 {

a - b

}

#[cfg(test)]

mod tests {

// Обратите внимание на эту полезную идиому: импортирование имён из внешней (для mod - тестов) области видимости.

use super::*;

#[test]

fn test_add() {

assert_eq!(add(1, 2), 3);

}

#[test]

fn test_bad_add() {

// Это утверждение запустится и проверка не сработает.

// Заметьте, что приватные функции также могут быть протестированы!

assert_eq!(bad_add(1, 2), 3);

}

}

Тесты могут быть запущены при помощи команды cargo test.

$ cargo test

running 2 tests

test tests::test_bad_add ... FAILED

test tests::test_add ... ok

failures:

---- tests::test_bad_add stdout ----

thread 'tests::test_bad_add' panicked at 'assertion failed: `(left == right)`

left: `-1`,

right: `3`', src/lib.rs:21:8

note: Run with `RUST_BACKTRACE=1` for a backtrace.

failures:

tests::test_bad_add

test result: FAILED. 1 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out

<p id="Тесты_и_"><strong><a l:href="#Тесты_и_">Тесты и</a><a l:href="#Тесты_и_">?</a></strong></p>

Ни один из предшествующих unit-тестов не имеют возвращаемый тип. Но в Rust 2018 ваши unit-тесты могут вернуть Result<()>, что позволяет использовать в них ?! Это может сделать их более краткими.

fn sqrt(number: f64) -> Result {

if number >= 0.0 {

Ok(number.powf(0.5))

} else {

Err("у отрицательного вещественного числа нет квадратного корня".to_owned())

}

}

#[cfg(test)]

mod tests {

use super::*;

#[test]

fn test_sqrt() -> Result<(), String> {

let x = 4.0;

assert_eq!(sqrt(x)?.powf(2.0), x);

Ok(())

}

}

הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה

Перейти на страницу:

Похожие книги

Писать нельзя молчать
Писать нельзя молчать

Неужели ты опять отложишь мечту – написать книгу? Опять занят и считаешь затею глупостью? А ведь чтобы сотворить историю нужно совсем немного: капелька поддержки на старте, чуток теории в процессе и безудержная энергия творчества, которую я помогу тебе разбудить. Или вспомнить.Мир живёт историями, и каждый может стать увлекательным рассказчиком. В этой книге я дам ответы на самые животрепещущие вопросы писателя-новичка. Эта книга для тех, кто:• Хочет писать истории, но откладывает дело в долгий ящик;• Писал раньше, но разуверился в своих силах;• Боится показаться глупым мечтателем в глазах близких;• Боится совершить ошибки;• Просто застрял и не знает, как воплотить свою идею;• Давно пишет, но не может довести до конца ни одну историю;• Не знает, как найти свою аудиторию, как с ней общаться;• Хочет почерпнуть вдохновение от общения с коллегой по писательскому делу.Эта книга написана без лишнего пафоса и с конкретными шагами на внедрение. Все, что остается, это сесть поудобнее и приступить к чтению.В формате PDF A4 сохранен издательский макет книги.

Юрий Михайлович Окунев , Юрий Окунев

Хобби и ремесла / Учебные пособия, самоучители / Дом и досуг