Entry tags:
Решение для запуска REPL приложения
Я придумал решение для запуска REPL приложения, упомянутое в предыдущем посте. Напомню формулировку: есть интерактивная процедура на Си++ со следующим интерфейсом.
Процедура работает в стиле REPL: берет ввод из входного потока, обрабатывает, выдаёт результат в выходной поток и ждёт следующего ввода. Мы хотим запустить эту процедуру из нашей программы на Си++, посылать ей команды и получать результат. Это, в частности, полезно для автоматического тестирования. Примерно так:void application(std::istream &input, std::ostream &output);
Решение выглядит в виде класса Interact и работает следующим образом:send("foo\n");
std::string reply = receive();
REQUIRE(reply == "bar\n");
Исходники можно взять на Гитхабе: https://github.com/sergev/interactРеализация должна быть понятна из комментариев.#include "interact.h" Interact session(application);
REQUIRE(session.receive() == "Hello!\n");
session.send("foo\n");
REQUIRE(session.receive() == "bar\n");
no subject
no subject
Я в чисто научном смысле. Как происходит обмен, не столь важно. Важно, что есть вход, и есть выход, и нет никакого внутреннего состояния.
no subject
f1(x1)
f2(x1,x2)
f3(x1,x2,x3)
...
fN(x1,x2,...,xN)
Здесь x1 - первый ввод, x2 - второй ввод и так далее.
Результат после ввода xN зависит как от xN, так и от всех предыдущих вводов.
Функция на каждом шаге тоже разная.
no subject
О, т.е. есть State. Ну окей. Можно рисовать как (S,I) => (S,O)
no subject
x2 = g1(x1,f(x1))
x3 = g2(x1,x2,f1(x1),f2(x1,x2))
и так далее. Здесь g1(), g2() и т.д. есть реакция юзера на поведение процедуры.
То есть имеем два дискретных ряда функций со взаимной зависимостью.
no subject
Э не. Это тест будет генерировать в зависимости - если такой тест. Или такой юзер. Но для тестирования собственно функциональности такая гипотеза вредна.
no subject
Мы можем тестировать application, а можем тестировать сам тест.
Старая программистская шутка: тестирование есть процесс поиска ошибок в тестах.