Современные гаджеты. Здоровье и красота
Поиск по сайту

Почему вам стоит начать вести разработку через тестирование. Тест на тему "технология разработки программного обеспечения" Функциональные возможности программы для реализации различных форм тестов и контроля знаний обучающихся

Главная цель данной статьи – помочь преодолеть страх, который возникает у тестировщиков ПО (как начинающих, так и опытных) к предстоящему интервью в связи с незнанием грядущего.

Второстепенная цель – собрать воедино основные вопросы, которые, вероятней всего, будут заданы на собеседовании. Как у начинающего тестировщика, у меня уже скопился определенный опыт подготовки к собеседованиям на данную должность, и я могу заметить, что даже специализированные QA форумы не справляются с этой целью, а может и не ставят ее перед собой вообще.

Перечень вопросов разумеется не окончательный и не претендует на образцовость, а выступает лишь своеобразным ориентиром при подготовке специалистов с тестирования ПО.

Собственно вопросы:

    Объясните термин «жизненный цикл программного обеспечения».

    Жизненным циклом программного обеспечения (SLC) является период времени, начинающийся с момента появления концепции ПО и заканчивающийся тогда, когда использование ПО более невозможно. Жизненный цикл программного обеспечения обычно включает в себя следующие этапы: концепт, описание требований, дизайн, реализация, тестирование, инсталляция и наладка, эксплуатация и поддержка и, иногда, этап вывода из эксплуатации. Данные фазы могут накладываться друг на друга или проводиться итерационно.

    Объясните термин «жизненный цикл разработки программного обеспечения».

    Жизненным циклом разработки программного обеспечения (SDLC) является концепция, которая описывает комплекс мероприятий, выполняемых на каждом этапе (фазе) разработки программного обеспечения.

    Объясните преимущество использования модели жизненного цикла разработки ПО (SDLC).

    • обеспечение основы проекта (методологии, активность...);
    • обеспечение визуализации хода реализации проекта;
    • помощь компании в эффективности и успешного завершения проекта (сокращение затрат, уменьшение сроков разработки и тестирования, повышение качества конечного продукта);
    • уменьшение рисков, связанных с процессом разработки ПО;
    • обеспечение специальным механизмом отслеживания прогресса проекта.
  1. Каковы основные фазы модели жизненного цикла разработки ПО?

    1. Принятия решения (идея) о необходимости создания ПО;
    2. Сбор и анализ требований;
    3. Дизайн (Системы и ПО) на основе требований;
    4. Кодирование на основе дизайна системы;
    5. Тестирование;
    6. Внедрение в пользовательскую среду;
    7. Сопровождение (в том числе фиксация найденных в пользовательской среде ошибок);
    8. Изъятие из эксплуатации (редко);
  2. Объясните, что такое Обеспечение качества (Quality Assurance)?

    Обеспечение качества (QA) - это совокупность мероприятий, охватывающих все технологические этапы разработки, выпуска и эксплуатации ПО и предпринимаемых на разных стадиях жизненного цикла ПО, для обеспечения требуемого уровня качества выпускаемого продукта.

    Обеспечение качества определено в стандарте ISO 9000:2005 «Системы менеджмента качества. Основные положения и словарь» как «часть менеджмента качества, направленная на создание уверенности в том, что требования к качеству будут выполнены».

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

    Объясните, что такое Контроль качества (Quality Control)?

    Контроль качества (QC) - это совокупность действий, проводимых над ПО в процессе разработки, для получения информации о его актуальном состоянии в аспектах готовности к выпуску, соответствия зафиксированным требованиям и соответствия заявленному уровню качества этого ПО.

    Объясните, что такое тестирование ПО?

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

    Из этого определения становится понятно, что тестирование ПО включает в себя два различных процесса:
    Валидация (validation): доказанное объективными результатами исследования подтверждение того, что требования для конкретного определенного использования приложения были выполнены.
    Верификация (verification): доказанное объективными результатами исследования подтверждение того, что определенные требования были выполнены.

    Какие основные цели тестирования ПО?

    Цель тестирования (test objective, test target) - это причина или цель разработки и выполнения теста.

    Основные цели:

    • обеспечить очищения ПО от ошибок (Вы не можете предоставить 100% покрытие, но Вы должны сделать все возможное, и гарантировать, что очевидные ошибки исправлены);
    • убедить, что ПО отвечает оригинальным требованиям и спецификации;
    • обеспечить уверенность в ПО (пользователям, заказчикам и т.д.).
  3. Когда следует начинать тестировать ПО?

    Простой ответ - как только это возможно! Более детально:

    • когда тестирование ПО проводится на ранней стадии, вы можете с легкостью повлиять на дизайн, так как его изменение на этой стадии не столь дорогостоящее чем на более поздних стадиях;
    • в свою очередь, чем раньше обнаруживается ошибка, тем дешевле она стоит компании;
    • также тестирование может начинаться до фактического получения ПО (статическое тестирование), что действительно немаловажно, так как снижает сложность провождения динамической стадии тестирования. Бытует мнение, что многие ошибки, которые найдены в стадии динамического тестирования, могли и должны были зафиксированные в стадии статического тестирования;
    • тестирование на ранних стадиях (изучение требований, спецификаций, бизнес случаев и т.д.) обеспечит тестировщику больше знаний о ПО, поможет обнаружить логические и технические ошибки, которые бы влияли на ПО, его конечный дизайн и стоимость.
  4. Когда следует заканчивать тестирование ПО?

    Простой ответ - управленческое решение, которое вероятней всего будет принято на основе:

    • тестового покрытия;
    • анализа рисков;
    • ухудшения тестирования.
    Более детальному изучению данного вопроса поможет Майкла Болтона в его блоге с разными там эвристиками «пиньяты» и «мертвой лошади».
  5. Какие основные уровни тестирования ПО?

    1. Компонентное (component)/ модульное тестирование (module, unit testing) - это тестирование отдельных компонентов ПО ;
    2. Интеграционное тестирование (integration testing) - это тестирование, выполняемое для обнаружения дефектов в интерфейсах и во взаимодействии между интегрированными компонентами или системами.

      Следует также понимать что такое big-bang тестирование, тестирование «сверху вниз», восходящие и инкрементное тестирование;

    3. Системное тестирование (system testing) - это процесс тестирования системы в целом с целью проверки того, что она соответствует установленным требованиям;
    4. Приёмочное тестирование (acceptance testing) - это формальное тестирование по отношению к потребностям, требованиям и бизнес процессам пользователя, проводимое с целью определения соответствия системы критериям приёмки (критерии выхода, которым должны соответствовать компонент или система, для того, чтобы быть принятыми пользователем, заказчиком или другим уполномоченным лицом) , с чего следуют такие виды , о которых желательно не забывать:
      • пользовательское приёмочное тестирование (user acceptance testing);
      • производственное приемочное тестирование (factory acceptance testing) - это приемочное тестирование, проводимое на стороне разработчика программного продукта и проводящееся сотрудниками компании-поставщика с целью определить, соответствует или нет компонент или система как программным, так и аппаратным требованиям;
      • стороннее приемочное тестирование (site acceptance testing) - это приёмочное тестирование пользователями или заказчиком на своей стороне. Проводится с целью определить как соответствие бизнес-процессу, так и удостовериться, что данная система или компонент удовлетворяет потребностям пользователей или заказчика. Обычно включает в себя проверку как программного обеспечения, так и технической базы;
      • эксплуатационное приемочное тестирование (operational acceptance testing) - это эксплуатационное тестирование в фазе приемочного тестирования, обычно выполняемое пользователем и/или сотрудниками с администраторским доступом, в рабочей среде (возможно, симулированой), фокусируясь на функциональных аспектах (восстанавливаемость, поведение ресурсов, устанавливаемость и техническое соответствие).
    5. Альфа-тестирование (alpha testing) - это моделируемое или действительное эксплуатационное тестирование потенциальными пользователями/заказчиками или независимой командой тестирования на стороне разработчиков, но вне разрабатывающей организации. Альфа-тестирование часто применяется к коробочному ПО в качестве внутреннего приёмочного тестирования;
    6. Бета-тестирование (beta testing) - это эксплуатационное тестирование потенциальными и/или существующими клиентами/заказчиками на внешней стороне никак не связанными с разработчиками, с целью определения действительно ли компонент или система удовлетворяет требованиям клиента/заказчика и вписывается в бизнес-процессы. Бета-тестирование часто проводится как форма внешнего приёмочного тестирования готового программного обеспечения для того чтобы получить отзывы рынка;
  6. Что такое критерии входа?

    Критерии входа (entry criteria) - это набор общих и специфичных условий для продолжения процесса с определенной задачей, например, фаза тестирования. Цель критериев входа - предотвращение начала задачи, которое может потребовать больше (бесполезных) усилий, чем на устранение не пройденных критериев входа.

    Проще говоря для Вас, как будущего тестировщика, критерии входа следует понимать как основные условия, которые должны быть выполнены до того, как Вы и Ваша команда могут начать тестирование.

    Приведите несколько примеров, которые объясняют критерии входа для тестирования ПО.

    • все дефекты, которые относятся к ранним стадиям (проектирования) закрыты и проверены;
    • код проверенный с помощью осуществления «Unit» тестов;
    • основные функциональные возможности ПО готовы для тестирования;
    • имеется документация, которая определяет требования;
    • все тестировщики ознакомлены с архитектурой ПО;
    • все тестировщики ознакомлены с целями проекта;
    • готова среда тестирования;
    • доступные для использования билды;
    • утверждены план тестирования и/или тестовые случаи.
  7. Что такое критерии выхода?

    Критерии выхода (exit criteria) - это набор общих и специфичных условий, согласованных заранее с заинтересованными сторонами, для того, чтобы процесс мог официально считаться завершенным. Цель критериев выхода - предотвращение возможности, когда задание считается завершенным, однако еще существуют отдельные незавершенные части задания. Критерии выхода используются для отчетности, а также планирования того, когда остановить тестирование.

    Проще говоря, как критерии входа определяют начало тестирования, так и критерии выхода определяют его окончание и ПО готово к следующему этапу жизненного цикла (внедрение и т.д.).

    Как вы объясните Bug/Defect/Error в ПО?

    Любая проблема/ошибка в ПО, что вызвана следующим поведением:

    • поломка ПО или отображение недействительного уведомления;
    • ПО предоставляет недействительные результаты;
    • ПО не удалось выполнить, как ожидалось (любое отклонение от ожидаемых результатов).
  8. Объясните процесс верификации.

    строим ли мы продукт правильно?

    Процесс верификации (verification) выполняется, чтобы убедиться, что каждый этап жизненного цикла разработки ПО (разработка, тестирование и т.д.) строится на основе предопределенных требований (requirements) и спецификаций (specifications) и без каких-либо отклонений от них. (см. № 7)

    Опишите различные мероприятия процесса верификации.

    • анализ различных аспектов тестирования (сроки, ресурсы, персонал, стоимость, инструменты тестирования и т.д.);
    • покрытие операторов (statement coverage) - процентное отношение операторов, исполняемых набором тестов, к их общему количеству; покрытие условий (condition coverage) - процент исходов условий, которые были проверены набором тестов. 100% покрытие условий требует, чтобы каждое отдельное условие в каждом выражении решения было проверено как Истина и Ложь; покрытие альтернатив (decision coverage) - процент результатов альтернативы, который был проверен набором тестов. Стопроцентное покрытие решений подразумевает стопроцентное покрытие ветвей и стопроцентное покрытие операторов;
    • рецензирование (review) - это оценка состояния продукта или проекта с целью установления расхождений с запланированными результатами и для выдвижения предложений по улучшению. Примерами рецензирования могут служить: управленческое рецензирование, неформальное рецензирование, технический анализ, инспекция и разбор;
    • разбор (walkthrough) - это пошаговый разбор, проводимый автором документа для сбора информации и обеспечения одинакового понимания содержания документа;
    • инспекция (inspection) - это тип равноправного анализа, основанный на визуальной проверке документов для поиска ошибок. Например, нарушение стандартов разработки и несоответствие документации более высокого уровня. Наиболее формальная методика рецензирования и поэтому всегда основывается на документированной процедуре.
  9. Приведите примеры верификации в зависимости от уровней тестирования. (см. № 11)

    1. Модульное тестирование (unit testing):
      -проверка осуществления проектирования программного обеспечения.
    2. Интеграционное тестирование (integration testing):
      -тестирование на интеграцию между всеми соответствующими компонентами до того как ПО перейдет к следующему уровню (system).
    3. Системное тестирование (system testing):
      -обеспечение соответствия системы предопределенным требованиям и спецификации.
    4. Приёмочное тестирование (acceptance testing):
      -убедитесь, что система отвечает требованиям клиента.
  10. Объясните процесс валидации.

    Реальный вопрос, на который мы ищем ответ: строим ли мы правильный продукт?

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

    Помните, валидация охватывает динамическую сторону тестирования, где определенное ПО тестируется и оценивается вопреки заданной SRS документации.

    Приведите несколько причин, которые приводят к багам в ПО.

    • человеческие ошибки (процесс проектирования и процесс реализации);
    • изменение требований в то время как ПО под испытанием;
    • непонимание требований и спецификаций;
    • отсутствие времени;
    • плохая приоритизация тестирования;
    • плохая ориентация в версиях ПО;
    • сложность самого ПО.
  11. Что такое процедура тестирования (Test Procedure)?

    Документ, описывающий последовательность действий при выполнении теста. Также известен как ручной сценарий тестирования.

    Что такое программный компонент?

    В основном, программные компоненты - это мелкие айтемы ПО, которые построены из еще мелких единиц, которые в свою очередь интегрированы вместе (классы, методы, хранимые процедуры, бинарные деревья и т.д.).

    Объясните Покрытие кода.

    Покрытие кода (code coverage) - это метод анализа, определяющий, какие части ПО были проверены (покрыты) набором тестов, а какие нет, например, покрытие операторов, покрытие альтернатив или покрытие условий.

    Объясните Инспекцию кода.

    Инспекция кода (code inspection) или просмотр кода (code review) - это систематическая проверка исходного кода программы с целью обнаружения и исправления ошибок, которые остались незамеченными в начальной фазе разработки. Целью просмотра является улучшение качества программного продукта и совершенствование навыков разработчика.
    В процессе инспекции могут быть найдены и устранены такие проблемы, как ошибки в форматировании строк, состояние гонки (race condition), утечка памяти (memory leak) и переполнение буфера (buffer overflow), что улучшает безопасность программного продукта. Системы контроля версий дают возможность проведения совместной инспекции кода. Кроме того, существуют специальные инструментальные средства для совместной инспекции кода.
    Программное обеспечение для автоматизированной инспекции кода упрощает задачу просмотра больших кусков кода, систематически сканируя его на предмет обнаружения наиболее известных уязвимостей.

    Что значит фраза Код завершен?

    Простой термин, имеющий отношение к конкретному этапу SDLC. Говоря «код завершен», мы на самом деле имеем ввиду, что его реализация завершена (вся функциональность ПО успешно реализована). Хотя если даже код будет полностью реализован, всегда есть новые ошибки обнаруженные во время тестирования.

    Что такое разбор (walkthrough) кода?

    Разбор (walkthrough) - это методика тестирования, используемая для обзора хода осуществления кода программистом и командой тестирования, во время разбора код выполняется с помощью нескольких простых тестов, чтобы определить его качество и логику.

    Что такое отладка?

    Отладка (debugging) - это процесс поиска, анализа, и устранения причин отказов и ошибок в ПО.

    Чтобы понять, где возникла ошибка, приходится:

    • узнавать текущие значения переменных;
    • выяснять, по какому пути выполнялась программа.
    Существуют две взаимодополняющие технологии отладки.
    • Использование отладчиков - программ, которые включают в себя пользовательский интерфейс для пошагового выполнения программы: оператор за оператором, функция за функцией, с остановками на некоторых строках исходного кода или при достижении определённого условия.
    • Вывод текущего состояния программы с помощью расположенных в критических точках программы операторов вывода - на экран, принтер, громкоговоритель или в файл. Вывод отладочных сведений в файл называется журналированием.
  12. Что такое эмулятор и симулятор?

    Эмуляция - это воспроизведение работы программы или системы (а не какой-то её мизерной части) с сохранением ключевых её свойств и принципов работы. Эмуляция выполняет программный код в привычной для этого кода среде, состоящей из тех же компонентов, что и эмулируемый объект.

    Симуляция - это воспроизведение работы программы-оригинала сугубо виртуально, на движке специальной программы (средство разработки курсов, к примеру). Симуляция лишь имитирует выполнение кода, а не копирует его, всё виртуально на 100%, всё «понарошку».

    Следовательно:

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

    Симулятор ПО - это модель оригинального ПО, в которой реализуется логика работы этого ПО (частично или полностью), имитируется поведение ПО, копируется его интерфейс.

    Симулятор по полноте функций/учитываемых параметров уже, чем эмулятор. Эмулируется объект, а симулируются его свойства, функции или поведение.

    Что такое спецификация ПО?

    Спецификация (specifications) - это текстовый файл с описанием того, что нужно протестировать в тестовых данных. В ней указывается какие результаты должна получить программа. Тестовый код находит реальные, вычисленные на живом коде результаты. А тестовый движок производит сверку спецификации и вычисленных результатов.

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

    Что такое кодирование?

    Кодирование (coding) - это процесс написания программного кода, скриптов, с целью реализации определённого алгоритма на определённом языке программирования.

    Некоторые путают такие понятия, как программирование и непосредственно кодирование. Кодирование является лишь частью программирования, наряду с анализом, проектированием, компиляцией, тестированием и отладкой, сопровождением (В узких кругах кодирование также может называться «кодинг». Однако, если верить Вики, в литературе этот термин используется редко.).

    Что такое требование?

    Требование (requirement) - совокупность утверждений относительно атрибутов, свойств или качеств программной системы, подлежащей реализации. Создаются в процессе разработки требований к программному обеспечению, в результате анализа требований.

    Требования могут выражаться в виде текстовых утверждений и графических моделей.

    В классическом техническом подходе совокупность требований используется на стадии проектирования программного обеспечения (ПО). Требования также используются в процессе тестирования ПО, так как тесты основываются на определённых требованиях.

    Этапу разработки требований, возможно, предшествовало технико-экономическое обоснование, или концептуальная фаза анализа проекта. Фаза разработки требований может быть разбита на выявление требований (сбор, понимание, рассмотрение и выяснение потребностей заинтересованных лиц), анализ (проверка целостности и законченности), спецификация (документирование требований) и проверка правильности.

    Что такое тестирование стабильности?

    Задачей тестирования стабильности (stability) / надежности (reliability) является проверка работоспособности приложения при длительном (многочасовом) тестировании со средним уровнем нагрузки. Время выполнения операций может играть в данном виде тестирования второстепенную роль. При этом на первое место выходит отсутствие утечек памяти, перезапусков серверов под нагрузкой и другие аспекты влияющие именно на стабильность работы.

    Расскажите про критичность (серьезность) бага и общепринятые уровни такой критичности.

    Критичность (severity) - это важность воздействия конкретного дефекта на разработку или функционирование компонента или системы.

    Критичность ошибки определяется тестировщиком, который обнаружил баг, но перед этим он должен ответить себе на такие вопросы:

    • Как эта ошибка будет влиять на процесс тестирования?
    • Как эта ошибка будет влиять на клиента?
    • Как эта ошибка влияет на систему?
    • Как эта ошибка влияет на сроки тестирования?
    • Блокирует ли эта ошибка другие тесты?
    • И т.д.
    Каждая компания может определить свою собственную шкалу для степени критичности (серьезности), но есть несколько уровней, которые используются почти всеми командами:
    • Blocker/show-stopper (блокирование) - ПО или конкретный компонент не подходит для использования/тестирования (полный отказ, краш системы и т.д.) и нет обхода.
      Примеры: система рухнет, когда пользователь нажимает кнопку «Пуск»; система не запускается после повреждения инсталлятора; отключение ПО, вызванное аппаратными сбоями.
    • Critical (критический) - главная функциональность не работает как надо, есть обходной путь, который может повлиять на целостность испытаний.
      Пример: ПО может рандомно крашиться, используя различные функциональные возможности; ПО вырабатывает противоречивые результаты, основные требования не удается подтвердить.
    • Major (важный) - поражение незначительных функциональностей, нет влияния на другие компоненты, и есть быстрый и действующий обход.
      Пример: Пользователь не может использовать определенную функциональность напрямую, но может использовать ее же, воспользовавшись доступом к ней из разных модулей.
    • Minor (второстепенный, незначительный) - незначительное воздействие на определенном месте, нет необходимости создавать обходной путь, целостность ПО не затронута.
      Примеры: ошибки орфографии, улучшения, запрос на изменение
  13. Расскажите про приоритет бага.

    Приоритет (priority) - это степень важности, присваиваемая багу. Другими словами определяется, насколько срочно это ошибка должна быть исправлена.

    Приоритет - инструмент менеджмента, и перед его определением последний должен ответить минимум на следующие вопросы:

    • Как баг влияет на сроки?
    • Как баг влияет на процесс тестирования?
    • Как баг влияет на работу остальных тестировщиков?
    • Каковы затраты необходимы на устранение бага?
    • Должны ли мы изменить требования к ПО?
  14. Что такое Сборка?

    Сборка (build) - подготовленный для использования информационный продукт. Чаще всего это исполняемый файл (двоичный файл, содержащий исполняемый код программы).

    Предположим, что номер версии сборки выглядит так: 1.35.6.2

    1. Первый идентификатор - основной номер версии.
    2. Второй идентификатор - дополнительный номер версии.
    3. Третий идентификатор - номер сборки.
    4. Четвёртый идентификатор - номер редакции.
  15. Можно ли начинать тестирование без рабочей сборки?

    Безусловно - да! Ведь существует два типа методологии тестирования (статическое и динамическое), которые позволяют тестировщику начинать работать без рабочей сборки статическим методом, тем более такой метод более рентабельный чем «динамический».

    Что такое статический анализ?

    Статический анализ (static analysis) - это анализ программных артефактов, таких как требования или программный код, проводимый без исполнения этих программных артефактов.

    Что такое тестовый драйвер и тестовая обвязка?

    Драйвер (driver) - это компонент ПО или средство тестирования, которое заменяет компонент, обеспечивающий управление и/или вызов компонента или системы.

    Обвязка (harness) - это тестовое окружение, включающее в себя заглушки и драйверы, необходимые для проведения теста.

    Что такое матрицы трассировки?

    Для измерения покрытия требований, необходимо проанализировать требования к продукту и разбить их на пункты. Опционально каждый пункт связывается с тест кейсами, проверяющими его. Совокупность этих связей - и является матрицей трассировки (traceability matrix). Проследив связи, можно понять какие именно требования проверяет тестовый случай.

    Тесты не связанные с требованиями не имеют смысла. Требования, не связанные с тестами - это «белые пятна», т.е. выполнив все созданные тест кейсы, нельзя дать ответ реализовано данное требование в продукте или нет.

    Что такое тестирование End-to-End?

    End-to-end тестирование - это тип тестирования где тестировщик использует ПО (сценарии, которые исследуют весь поток выполнения) в условиях которыми вероятней всего обладает пользователь.

    В дополнение, тесты будут работать сочетая в себе несколько сценариев уместных в реальном мире:

    • запуск ПО в среде с задержками связи сети;
    • запуск ПО в среде с низкими ресурсами;
    • Запуск ПО на другом серверном оборудовании;
    • Запустите ПО в той же среде, что имеет некоторые другие приложения, которые потребляют ресурсы сервера.
  16. Что такое функциональное тестирование? Какие основные типы функционального тестирования? Какие виды функциональных тестов вы знаете?

    Функциональное тестирование (functional testing) - это тестирование, основанное на анализе спецификации функциональности компонента или системы.

    Функциональные тесты базируются на функциях и особенностях, а также взаимодействии с другими системами, и могут быть представлены на всех уровнях тестирования: компонентном или модульном (Component/Unit testing), интеграционном (Integration testing), системном (System testing) иприемочном (Acceptance testing). Функциональные виды тестирования рассматривают внешнее поведение системы.

    1. Функциональные тесты основываются на функциях, выполняемых системой, и могут проводиться на всех уровнях тестирования (компонентном, интеграционном, системном, приемочном). Как правило, эти функции описываются в требованиях, функциональных спецификациях или в виде случаев использования системы (use cases). Тестирование функциональности может проводиться в двух аспектах:
      • тестирование в перспективе «требования» (requirement-based testing) использует спецификацию функциональных требований к системе как основу для дизайна тестовых случаев (Test Cases). В этом случае необходимо сделать список того, что будет тестироваться, а что нет; приоритезировать требования на основе рисков (если это не сделано в документе с требованиями), а на основе этого приоритезировать тестовые сценарии (test cases). Это позволит сфокусироваться и не упустить при тестировании наиболее важный функционал.
      • тестирование в перспективе «бизнес-процессы» (business-process-based testing) использует знание этих самых бизнес-процессов, которые описывают сценарии ежедневного использования системы. В этой перспективе тестовые сценарии (test scripts), как правило, основываются на случаях использования системы (use cases).
    2. Tестирование защищенности (security testing) - это тестирование с целью оценить защищенность ПО. Общая стратегия безопасности основывается на трех основных принципах:
      • конфиденциальность;
      • целостность;
      • доступность;
      В настоящее время наиболее распространенными видами уязвимости в безопасности программного обеспечения являются:
      • xss (cross-site scripting) - это вид уязвимости программного обеспечения (Web приложений), при которой, на генерированной сервером странице, выполняются вредоносные скрипты, с целью атаки клиента;
      • xsrf / csrf (request forgery) - это вид уязвимости, позволяющий использовать недостатки HTTP протокола, при этом злоумышленники работают по следующей схеме: ссылка на вредоносный сайт установливается на странице, пользующейся доверием у пользователя, при переходе по вредоносной ссылке выполняется скрипт, сохраняющий личные данные пользователя (пароли, платежные данные и т.д.), либо отправляющий СПАМ сообщения от лица пользователя, либо изменяет доступ к учетной записи пользователя, для получения полного контроля над ней;
      • code injections (sql, php, asp и т.д.) - это вид уязвимости, при котором становится возможно осуществить запуск исполняемого кода с целью получения доступа к системным ресурсам, несанкционированного доступа к данным либо выведения системы из строя;
      • server-side includes (ssi) injection - это вид уязвимости, использующий вставку серверных команд в HTML код или запуск их напрямую с сервера;
      • authorization bypass - это вид уязвимости, при котором возможно получить несанкционированный доступ к учетной записи или документам другого пользователя.
    3. (interoperability testing) - это процесс тестирования для определения возможности взаимодействия программного продукта.
    Функциональное тестирование разделяются по ожидаемому результату на позитивные и негативные тесты:
    • Позитивный тест использует только корректные данные и проверяет, что приложение правильно выполнило вызываемую функцию.
    • Негативный тест оперирует как корректными так и некорректными данными (минимум 1 некорректный параметр) и ставит целью проверку исключительных ситуаций (срабатывание валидаторов), а также проверяет, что вызываемая приложением функция не выполняется при срабатывании валидатора.
  17. Что такое нефункциональное тестирование?

    Нефункциональное тестирование (non-functional testing) - это тестирование атрибутов компонента или системы, не относящихся к функциональности, то есть надежность, эффективность, практичность, сопровождаемость, переносимость и т.д. (тесты, сделанные по всем аспектам, которые непосредственно не связанны с конкретным действием пользователя).

    Несколько примеров тестов, которые включает в себе нефункциональное тестирование?

    1. Тестирование переносимости (portability testing) это процесс тестирования с целью определить переносимость программного продукта.
    2. Тестирование возможности взаимодействия (interoperability testing) - это Процесс тестирования для определения возможности взаимодействия программного продукта.
    3. Тестирование производительности (performance testing) - это процесс тестирования с целью определить производительность программного продукта.
    4. Тестирование надежности (reliability testing) - это процесс тестирования, исследующий надежность программного продукта.
    5. Тестирование практичности (usability testing) - это тестирование с целью определения степени понятности, легкости в изучении и использовании, привлекательности программного продукта для пользователя при условии использования в заданных условиях эксплуатации.
    6. Тестирование безопасности (safety testing) - это тестирование программного продукта с целью определить его безопасность.
    7. Стрессовое тестирование (stress testing) - это вид тестирования производительности, оценивающий систему или компонент на граничных значениях рабочих нагрузок или за их пределами, или же в состоянии ограниченных ресурсов, таких как память или доступ к серверу.
    8. Нагрузочное тестирование (load testing) - это вид тестирования производительности, проводимый с целью оценить поведение компонента или системы под увеличивающейся нагрузкой (число одновременно работающих пользователей и/или число транзакций) для определения максимально допустимого уровня нагрузки для исследуемого компонента или системы.
  18. Что такое тестирование Белого ящика?

    Белый ящик - это тестирование кода на предмет логики работы программы и корректности её работы с точки зрения компилятора того языка, на котором она писалась.

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

    Техника Белого ящика включает в себя следующие методы тестирования:

    • покрытие решений;
    • покрытие условий;
    • покрытие решений и условий;
    • комбинаторное покрытие условий;
  19. Что такое тестирование Чёрного ящика?

    Тестирование чёрного ящика или поведенческое тестирование - это стратегия (метод) тестирования функционального поведения ПО с точки зрения внешнего мира, при котором не используется знание о внутреннем устройстве тестируемого объекта. Под стратегией понимаются систематические методы отбора и создания тестов для тестового набора. Стратегия поведенческого теста исходит из технических требований и их спецификаций

    Некоторые приёмы тестирования чёрного ящика:

    • эквивалентное разбиение;
    • анализ граничных значений;
    • анализ причинно-следственных связей;
    • предположение об ошибке;
  20. Что такое Конверсионное тестирование?

    Конверсионное тестирование (сonversion testing) - это методика тестирования, что используется для проверки того, как имеющие в системе А данные будут преобразовываться и становиться доступными для использования в системе Б.

    Что такое Конформационное тестирование?

    Конформационное тестирование - это тестирование с целью убедиться, что ПО отвечает определенным отраслевым стандартам (IEEE, W3C и т.д.) для разработки ПО.

Спасибо за внимание и удачи в ваших начинаниях!

P.S. Пожалуйста, обратите внимание, что это всего лишь перечень вопросов составленный на основе моего опыта (он не будет уникальным для всех интервью), а запоминание ответов как истинных может помешать вам работать в индустрии. Целью является помочь вам понять основные вопросы, с которыми вы предположено столкнетесь во время собеседования.

Призываю к активному и обоснованному холивару!

Недавно был на собеседовании на Middle QA на проект, который явно превышает мои возможности. Уделил много времени тому, чего не знал вообще и мало времени повторению простой теории, а зря.

Ниже основы основ для повторения перед собеседованием для Trainee and Junior: определение тестирования, качество , верификация / валидация , цели, этапы, тест план, пункты тест плана, тест дизайн, техники тест дизайна, traceability matrix , test case, чек-лист, дефект, error/deffect/failure , баг репорт, severity vs priority, уровни тестирования, виды / типы, подходы к интеграционному тестированию , принципы тестирования, статическое и динамическое тестирование, исследовательское / ad-hoc тестирование, требования, жизненный цикл бага, стадии разработки ПО, decision table, qa/qc/test engineer, диаграмма связей.

Все замечания, корректировки и дополнения очень приветствуются.

Тестирование программного обеспечения - проверка соответствия между реальным и ожидаемым поведением программы, осуществляемая на конечном наборе тестов, выбранном определенным образом. В более широком смысле, тестирование - это одна из техник контроля качества, включающая в себя активности по планированию работ (Test Management), проектированию тестов (Test Design), выполнению тестирования (Test Execution) и анализу полученных результатов (Test Analysis).

Качество программного обеспечения (Software Quality) - это совокупность характеристик программного обеспечения, относящихся к его способности удовлетворять установленные и предполагаемые потребности.

Верификация (verification) - это процесс оценки системы или её компонентов с целью определения удовлетворяют ли результаты текущего этапа разработки условиям, сформированным в начале этого этапа. Т.е. выполняются ли наши цели, сроки, задачи по разработке проекта, определенные в начале текущей фазы.
Валидация (validation) - это определение соответствия разрабатываемого ПО ожиданиям и потребностям пользователя, требованиям к системе .
Также можно встретить иную интерпритацию:
Процесс оценки соответствия продукта явным требованиям (спецификациям) и есть верификация (verification), в то же время оценка соответствия продукта ожиданиям и требованиям пользователей - есть валидация (validation). Также часто можно встретить следующее определение этих понятий:
Validation - ’is this the right specification?’.
Verification - ’is the system correct to specification?’.

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

Этапы тестирования:
1. Анализ продукта
2. Работа с требованиями
3. Разработка стратегии тестирования
и планирование процедур контроля качества
4. Создание тестовой документации
5. Тестирование прототипа
6. Основное тестирование
7. Стабилизация
8. Эксплуатация

Тест план (Test Plan) - это документ, описывающий весь объем работ по тестированию, начиная с описания объекта, стратегии, расписания, критериев начала и окончания тестирования, до необходимого в процессе работы оборудования, специальных знаний, а также оценки рисков с вариантами их разрешения.
Отвечает на вопросы:
Что надо тестировать?
Что будете тестировать?
Как будете тестировать?
Когда будете тестировать?
Критерии начала тестирования.
Критерии окончания тестирования.

Основные пункты тест плана
В стандарте IEEE 829 перечислены пункты, из которых должен (пусть - может) состоять тест-план:
a) Test plan identifier;
b) Introduction;
c) Test items;
d) Features to be tested;
e) Features not to be tested;
f) Approach;
g) Item pass/fail criteria;
h) Suspension criteria and resumption requirements;
i) Test deliverables;
j) Testing tasks;
k) Environmental needs;
l) Responsibilities;
m) Staffing and training needs;
n) Schedule;
o) Risks and contingencies;
p) Approvals.

Тест дизайн – это этап процесса тестирования ПО, на котором проектируются и создаются тестовые сценарии (тест кейсы), в соответствии с определёнными ранее критериями качества и целями тестирования.
Роли, ответственные за тест дизайн:
Тест аналитик - определяет «ЧТО тестировать?»
Тест дизайнер - определяет «КАК тестировать?»

Техники тест дизайна

Эквивалентное Разделение (Equivalence Partitioning - EP) . Как пример, у вас есть диапазон допустимых значений от 1 до 10, вы должны выбрать одно верное значение внутри интервала, скажем, 5, и одно неверное значение вне интервала - 0.

Анализ Граничных Значений (Boundary Value Analysis - BVA). Если взять пример выше, в качестве значений для позитивного тестирования выберем минимальную и максимальную границы (1 и 10), и значения больше и меньше границ (0 и 11). Анализ Граничный значений может быть применен к полям, записям, файлам, или к любого рода сущностям имеющим ограничения.

Причина / Следствие (Cause/Effect - CE). Это, как правило, ввод комбинаций условий (причин), для получения ответа от системы (Следствие). Например, вы проверяете возможность добавлять клиента, используя определенную экранную форму. Для этого вам необходимо будет ввести несколько полей, таких как «Имя», «Адрес», «Номер Телефона» а затем, нажать кнопку «Добавить» - это «Причина». После нажатия кнопки «Добавить», система добавляет клиента в базу данных и показывает его номер на экране - это «Следствие».

Предугадывание ошибки (Error Guessing - EG). Это когда тестировщик использует свои знания системы и способность к интерпретации спецификации на предмет того, чтобы «предугадать» при каких входных условиях система может выдать ошибку. Например, спецификация говорит: «пользователь должен ввести код». Тестировщик будет думать: «Что, если я не введу код?», «Что, если я введу неправильный код? », и так далее. Это и есть предугадывание ошибки.

Исчерпывающее тестирование (Exhaustive Testing - ET) - это крайний случай. В пределах этой техники вы должны проверить все возможные комбинации входных значений, и в принципе, это должно найти все проблемы. На практике применение этого метода не представляется возможным, из-за огромного количества входных значений.

Попарное тестирование (Pairwise Testing) - это техника формирования наборов тестовых данных. Сформулировать суть можно, например, вот так: формирование таких наборов данных, в которых каждое тестируемое значение каждого из проверяемых параметров хотя бы единожды сочетается с каждым тестируемым значением всех остальных проверяемых параметров.

Допустим, какое-то значений (налог) для человека рассчитывается на основании его пола, возраста и наличия детей - получаем три входных параметра, для каждого из которых для тестов выбираем каким-то образом значения. Например: пол - мужской или женский; возраст - до 25, от 25 до 60, более 60; наличие детей - да или нет. Для проверки правильности расчётов можно, конечно, перебрать все комбинации значений всех параметров:

пол возраст дети
1 мужчина до 25 детей нет
2 женщина до 25 детей нет
3 мужчина 25-60 детей нет
4 женщина 25-60 детей нет
5 мужчина старше 60 детей нет
6 женщина старше 60 детей нет
7 мужчина до 25 дети есть
8 женщина до 25 дети есть
9 мужчина 25-60 дети есть
10 женщина 25-60 дети есть
11 мужчина старше 60 дети есть
12 женщина старше 60 дети есть

А можно решить, что нам не нужны сочетания значений всех параметров со всеми, а мы хотим только убедиться, что мы проверим все уникальные пары значений параметров. Т.е., например, с точки зрения параметров пола и возраста мы хотим убедиться, что мы точно проверим мужчину до 25, мужчину между 25 и 60, мужчину после 60, а также женщину до 25, женщину между 25 и 60, ну и женщину после 60. И точно так же для всех остальных пар параметров. И таким образом, мы можем получить гораздо меньше наборов значений (в них есть все пары значений, правда некоторые дважды):

пол возраст дети
1 мужчина до 25 детей нет
2 женщина до 25 дети есть
3 мужчина 25-60 дети есть
4 женщина 25-60 детей нет
5 мужчина старше 60 детей нет
6 женщина старше 60 дети есть

Такой подход примерно и составляет суть техники pairwise testing - мы не проверяем все сочетания всех значений, но проверяем все пары значений.

Traceability matrix - Матрица соответствия требований - это двумерная таблица, содержащая соответсвие функциональных требований (functional requirements) продукта и подготовленных тестовых сценариев (test cases). В заголовках колонок таблицы расположены требования, а в заголовках строк - тестовые сценарии. На пересечении - отметка, означающая, что требование текущей колонки покрыто тестовым сценарием текущей строки.
Матрица соответсвия требований используется QA-инженерами для валидации покрытия продукта тестами. МСТ является неотъемлемой частью тест-плана.

Тестовый сценарий (Test Case) - это артефакт, описывающий совокупность шагов, конкретных условий и параметров, необходимых для проверки реализации тестируемой функции или её части.
Пример:
Action Expected Result Test Result
(passed/failed/blocked)
Open page «login» Login page is opened Passed

Каждый тест кейс должен иметь 3 части:
PreConditions Список действий, которые приводят систему к состоянию пригодному для проведения основной проверки. Либо список условий, выполнение которых говорит о том, что система находится в пригодном для проведения основного теста состояния.
Test Case Description Список действий, переводящих систему из одного состояния в другое, для получения результата, на основании которого можно сделать вывод о удовлетворении реализации, поставленным требованиям
PostConditions Список действий, переводящих систему в первоначальное состояние (состояние до проведения теста - initial state)
Виды Тестовых Сценариев:
Тест кейсы разделяются по ожидаемому результату на позитивные и негативные:
Позитивный тест кейс использует только корректные данные и проверяет, что приложение правильно выполнило вызываемую функцию.
Негативный тест кейс оперирует как корректными так и некорректными данными (минимум 1 некорректный параметр) и ставит целью проверку исключительных ситуаций (срабатывание валидаторов), а также проверяет, что вызываемая приложением функция не выполняется при срабатывании валидатора.

Чек-лист (check list) - это документ, описывающий что должно быть протестировано. При этом чек-лист может быть абсолютно разного уровня детализации. На сколько детальным будет чек-лист зависит от требований к отчетности, уровня знания продукта сотрудниками и сложности продукта.
Как правило, чек-лист содержит только действия (шаги), без ожидаемого результата. Чек-лист менее формализован чем тестовый сценарий. Его уместно использовать тогда, когда тестовые сценарии будут избыточны. Также чек-лист ассоциируются с гибкими подходами в тестировании.

Дефект (он же баг) – это несоответствие фактического результата выполнения программы ожидаемому результату. Дефекты обнаруживаются на этапе тестирования программного обеспечения (ПО), когда тестировщик проводит сравнение полученных результатов работы программы (компонента или дизайна) с ожидаемым результатом, описанным в спецификации требований.

Error - ошибка пользователя, то есть он пытается использовать программу иным способом.
Пример - вводит буквы в поля, где требуется вводить цифры (возраст, количество товара и т.п.).
В качественной программе предусмотрены такие ситуации и выдаются сообщение об ошибке (error message), с красным крестиком которые.
Bug (defect) - ошибка программиста (или дизайнера или ещё кого, кто принимает участие в разработке), то есть когда в программе, что-то идёт не так как планировалось и программа выходит из-под контроля. Например, когда никак не контроллируется ввод пользователя, в результате неверные данные вызывают краши или иные «радости» в работе программы. Либо внутри программа построена так, что изначально не соответствует тому, что от неё ожидается.
Failure - сбой (причём не обязательно аппаратный) в работе компонента, всей программы или системы. То есть, существуют такие дефекты, которые приводят к сбоям (A defect caused the failure) и существуют такие, которые не приводят. UI-дефекты например. Но аппаратный сбой, никак не связанный с software, тоже является failure.

Баг Репорт (Bug Report) - это документ, описывающий ситуацию или последовательность действий приведшую к некорректной работе объекта тестирования, с указанием причин и ожидаемого результата.
Шапка
Короткое описание (Summary) Короткое описание проблемы, явно указывающее на причину и тип ошибочной ситуации.
Проект (Project) Название тестируемого проекта
Компонент приложения (Component) Название части или функции тестируемого продукта
Номер версии (Version) Версия на которой была найдена ошибка
Серьезность (Severity) Наиболее распространена пятиуровневая система градации серьезности дефекта:
S1 Блокирующий (Blocker)
S2 Критический (Critical)
S3 Значительный (Major)
S4 Незначительный (Minor)
S5 Тривиальный (Trivial)
Приоритет (Priority) Приоритет дефекта:
P1 Высокий (High)
P2 Средний (Medium)
P3 Низкий (Low)
Статус (Status) Статус бага. Зависит от используемой процедуры и жизненного цикла бага (bug workflow and life cycle)

Автор (Author) Создатель баг репорта
Назначен на (Assigned To) Имя сотрудника, назначенного на решение проблемы
Окружение
ОС / Сервис Пак и т.д. / Браузера + версия /… Информация об окружении, на котором был найден баг: операционная система, сервис пак, для WEB тестирования - имя и версия браузера и т.д.

Описание
Шаги воспроизведения (Steps to Reproduce) Шаги, по которым можно легко воспроизвести ситуацию, приведшую к ошибке.
Фактический Результат (Result) Результат, полученный после прохождения шагов к воспроизведению
Ожидаемый результат (Expected Result) Ожидаемый правильный результат
Дополнения
Прикрепленный файл (Attachment) Файл с логами, скриншот или любой другой документ, который может помочь прояснить причину ошибки или указать на способ решения проблемы

Severity vs Priority
Серьезность (Severity) - это атрибут, характеризующий влияние дефекта на работоспособность приложения.
Приоритет (Priority) - это атрибут, указывающий на очередность выполнения задачи или устранения дефекта. Можно сказать, что это инструмент менеджера по планированию работ. Чем выше приоритет, тем быстрее нужно исправить дефект.
Severity выставляется тестировщиком
Priority – менеджером, тимлидом или заказчиком

Градация Серьезности дефекта (Severity)

S1 Блокирующая (Blocker)
Блокирующая ошибка, приводящая приложение в нерабочее состояние, в результате которого дальнейшая работа с тестируемой системой или ее ключевыми функциями становится невозможна. Решение проблемы необходимо для дальнейшего функционирования системы.

S2 Критическая (Critical)
Критическая ошибка, неправильно работающая ключевая бизнес логика, дыра в системе безопасности, проблема, приведшая к временному падению сервера или приводящая в нерабочее состояние некоторую часть системы, без возможности решения проблемы, используя другие входные точки. Решение проблемы необходимо для дальнейшей работы с ключевыми функциями тестируемой системой.

S3 Значительная (Major)
Значительная ошибка, часть основной бизнес логики работает некорректно. Ошибка не критична или есть возможность для работы с тестируемой функцией, используя другие входные точки.

S4 Незначительная (Minor)
Незначительная ошибка, не нарушающая бизнес логику тестируемой части приложения, очевидная проблема пользовательского интерфейса.

S5 Тривиальная (Trivial)
Тривиальная ошибка, не касающаяся бизнес логики приложения, плохо воспроизводимая проблема, малозаметная посредствам пользовательского интерфейса, проблема сторонних библиотек или сервисов, проблема, не оказывающая никакого влияния на общее качество продукта.

Градация Приоритета дефекта (Priority)
P1 Высокий (High)
Ошибка должна быть исправлена как можно быстрее, т.к. ее наличие является критической для проекта.
P2 Средний (Medium)
Ошибка должна быть исправлена, ее наличие не является критичной, но требует обязательного решения.
P3 Низкий (Low)
Ошибка должна быть исправлена, ее наличие не является критичной, и не требует срочного решения.

Уровни Тестирования

1. Модульное тестирование (Unit Testing)
Компонентное (модульное) тестирование проверяет функциональность и ищет дефекты в частях приложения, которые доступны и могут быть протестированы по-отдельности (модули программ, объекты, классы, функции и т.д.).

2. Интеграционное тестирование (Integration Testing)
Проверяется взаимодействие между компонентами системы после проведения компонентного тестирования.

3. Системное тестирование (System Testing)
Основной задачей системного тестирования является проверка как функциональных, так и не функциональных требований в системе в целом. При этом выявляются дефекты, такие как неверное использование ресурсов системы, непредусмотренные комбинации данных пользовательского уровня, несовместимость с окружением, непредусмотренные сценарии использования, отсутствующая или неверная функциональность, неудобство использования и т.д.

4. Операционное тестирование (Release Testing).
Даже если система удовлетворяет всем требованиям, важно убедиться в том, что она удовлетворяет нуждам пользователя и выполняет свою роль в среде своей эксплуатации, как это было определено в бизнес моделе системы. Следует учесть, что и бизнес модель может содержать ошибки. Поэтому так важно провести операционное тестирование как финальный шаг валидации. Кроме этого, тестирование в среде эксплуатации позволяет выявить и нефункциональные проблемы, такие как: конфликт с другими системами, смежными в области бизнеса или в программных и электронных окружениях; недостаточная производительность системы в среде эксплуатации и др. Очевидно, что нахождение подобных вещей на стадии внедрения - критичная и дорогостоящая проблема. Поэтому так важно проведение не только верификации, но и валидации, с самых ранних этапов разработки ПО.

5. Приемочное тестирование (Acceptance Testing)
Формальный процесс тестирования, который проверяет соответствие системы требованиям и проводится с целью:
определения удовлетворяет ли система приемочным критериям;
вынесения решения заказчиком или другим уполномоченным лицом принимается приложение или нет.

Виды / типы тестирования

Функциональные виды тестирования

Функциональное тестирование (Functional testing)
Тестирование пользовательского интерфейса (GUI Testing)
Тестирование безопасности (Security and Access Control Testing)
Тестирование взаимодействия (Interoperability Testing)

Нефункциональные виды тестирования

Все виды тестирования производительности:
o нагрузочное тестирование (Performance and Load Testing)
o стрессовое тестирование (Stress Testing)
o тестирование стабильности или надежности (Stability / Reliability Testing)
o объемное тестирование (Volume Testing)
Тестирование установки (Installation testing)
Тестирование удобства пользования (Usability Testing)
Тестирование на отказ и восстановление (Failover and Recovery Testing)
Конфигурационное тестирование (Configuration Testing)

Связанные с изменениями виды тестирования

Дымовое тестирование (Smoke Testing)
Регрессионное тестирование (Regression Testing)
Повторное тестирование (Re-testing)
Тестирование сборки (Build Verification Test)
Санитарное тестирование или проверка согласованности/исправности (Sanity Testing)

Функциональное тестирование рассматривает заранее указанное поведение и основывается на анализе спецификаций функциональности компонента или системы в целом.

Тестирование пользовательского интерфейса (GUI Testing) - функциональная проверка интерфейса на соответствие требованиям - размер, шрифт, цвет, consistent behavior.

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

Тестирование взаимодействия (Interoperability Testing) – это функциональное тестирование, проверяющее способность приложения взаимодействовать с одним и более компонентами или системами и включающее в себя тестирование совместимости (compatibility testing) и интеграционное тестирование

Нагрузочное тестирование - это автоматизированное тестирование, имитирующее работу определенного количества бизнес пользователей на каком-либо общем (разделяемом ими) ресурсе.

Стрессовое тестирование (Stress Testing) позволяет проверить насколько приложение и система в целом работоспособны в условиях стресса и также оценить способность системы к регенерации, т.е. к возвращению к нормальному состоянию после прекращения воздействия стресса. Стрессом в данном контексте может быть повышение интенсивности выполнения операций до очень высоких значений или аварийное изменение конфигурации сервера. Также одной из задач при стрессовом тестировании может быть оценка деградации производительности, таким образом цели стрессового тестирования могут пересекаться с целями тестирования производительности.

Объемное тестирование (Volume Testing). Задачей объемного тестирования является получение оценки производительности при увеличении объемов данных в базе данных приложения

Тестирование стабильности или надежности (Stability / Reliability Testing). Задачей тестирования стабильности (надежности) является проверка работоспособности приложения при длительном (многочасовом) тестировании со средним уровнем нагрузки.

Тестирование установки направленно на проверку успешной инсталляции и настройки, а также обновления или удаления программного обеспечения.

Тестирование удобства пользования - это метод тестирования, направленный на установление степени удобства использования, обучаемости, понятности и привлекательности для пользователей разрабатываемого продукта в контексте заданных условий. Сюда также входит:
User eXperience (UX) - ощущение, испытываемое пользователем во время использования цифрового продукта, в то время как User interface - это инструмент, позволяющий осуществлять интеракцию «пользователь - веб-ресурс».

Тестирование на отказ и восстановление (Failover and Recovery Testing) проверяет тестируемый продукт с точки зрения способности противостоять и успешно восстанавливаться после возможных сбоев, возникших в связи с ошибками программного обеспечения, отказами оборудования или проблемами связи (например, отказ сети). Целью данного вида тестирования является проверка систем восстановления (или дублирующих основной функционал систем), которые, в случае возникновения сбоев, обеспечат сохранность и целостность данных тестируемого продукта.

Конфигурационное тестирование (Configuration Testing) - специальный вид тестирования, направленный на проверку работы программного обеспечения при различных конфигурациях системы (заявленных платформах, поддерживаемых драйверах, при различных конфигурациях компьютеров и т.д.)

Дымовое (Smoke) тестирование рассматривается как короткий цикл тестов, выполняемый для подтверждения того, что после сборки кода (нового или исправленного) устанавливаемое приложение, стартует и выполняет основные функции.

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

Повторное тестирование - тестирование, во время которого исполняются тестовые сценарии, выявившие ошибки во время последнего запуска, для подтверждения успешности исправления этих ошибок.
В чем разница между regression testing и re-testing?
Re-testing - проверяется исправление багов
Regression testing - проверяется то, что исправление багов, а также любые изменения в коде приложения, не повлияли на другие модули ПО и не вызвало новых багов.

Тестирование сборки или Build Verification Test - тестирование направленное на определение соответствия, выпущенной версии, критериям качества для начала тестирования. По своим целям является аналогом Дымового Тестирования, направленного на приемку новой версии в дальнейшее тестирование или эксплуатацию. Вглубь оно может проникать дальше, в зависимости от требований к качеству выпущенной версии.

Санитарное тестирование - это узконаправленное тестирование достаточное для доказательства того, что конкретная функция работает согласно заявленным в спецификации требованиям. Является подмножеством регрессионного тестирования. Используется для определения работоспособности определенной части приложения после изменений произведенных в ней или окружающей среде. Обычно выполняется вручную.

Подходы к интеграционному тестированию:
Снизу вверх (Bottom Up Integration)
Все низкоуровневые модули, процедуры или функции собираются воедино и затем тестируются. После чего собирается следующий уровень модулей для проведения интеграционного тестирования. Данный подход считается полезным, если все или практически все модули, разрабатываемого уровня, готовы. Также данный подход помогает определить по результатам тестирования уровень готовности приложения.
Сверху вниз (Top Down Integration)
Вначале тестируются все высокоуровневые модули, и постепенно один за другим добавляются низкоуровневые. Все модули более низкого уровня симулируются заглушками с аналогичной функциональностью, затем по мере готовности они заменяются реальными активными компонентами. Таким образом мы проводим тестирование сверху вниз.
Большой взрыв («Big Bang» Integration)
Все или практически все разработанные модули собираются вместе в виде законченной системы или ее основной части, и затем проводится интеграционное тестирование. Такой подход очень хорош для сохранения времени. Однако если тест кейсы и их результаты записаны не верно, то сам процесс интеграции сильно осложнится, что станет преградой для команды тестирования при достижении основной цели интеграционного тестирования.

Принципы тестирования

Принцип 1 – Тестирование демонстрирует наличие дефектов (Testing shows presence of defects)
Тестирование может показать, что дефекты присутствуют, но не может доказать, что их нет. Тестирование снижает вероятность наличия дефектов, находящихся в программном обеспечении, но, даже если дефекты не были обнаружены, это не доказывает его корректности.

Принцип 2 – Исчерпывающее тестирование недостижимо (Exhaustive testing is impossible)
Полное тестирование с использованием всех комбинаций вводов и предусловий физически невыполнимо, за исключением тривиальных случаев. Вместо исчерпывающего тестирования должны использоваться анализ рисков и расстановка приоритетов, чтобы более точно сфокусировать усилия по тестированию.

Принцип 3 – Раннее тестирование (Early testing)
Чтобы найти дефекты как можно раньше, активности по тестированию должны быть начаты как можно раньше в жизненном цикле разработки программного обеспечения или системы, и должны быть сфокусированы на определенных целях.

Принцип 4 – Скопление дефектов (Defects clustering)
Усилия тестирования должны быть сосредоточены пропорционально ожидаемой, а позже реальной плотности дефектов по модулям. Как правило, большая часть дефектов, обнаруженных при тестировании или повлекших за собой основное количество сбоев системы, содержится в небольшом количестве модулей.

Принцип 5 – Парадокс пестицида (Pesticide paradox)
Если одни и те же тесты будут прогоняться много раз, в конечном счете этот набор тестовых сценариев больше не будет находить новых дефектов. Чтобы преодолеть этот “парадокс пестицида”, тестовые сценарии должны регулярно рецензироваться и корректироваться, новые тесты должны быть разносторонними, чтобы охватить все компоненты программного обеспечения,
или системы, и найти как можно больше дефектов.

Принцип 6 – Тестирование зависит от контекста (Testing is concept depending)
Тестирование выполняется по-разному в зависимости от контекста. Например, программное обеспечение, в котором критически важна безопасность, тестируется иначе, чем сайт электронной коммерции.
Принцип 7 – Заблуждение об отсутствии ошибок (Absence-of-errors fallacy)
Обнаружение и исправление дефектов не помогут, если созданная система не подходит пользователю и не удовлетворяет его ожиданиям и потребностям.

Cтатическое и динамическое тестирование
Статическое тестирование отличается от динамического тем, что производится без запуска программного кода продукта. Тестирование осуществляется путем анализа программного кода (code review) или скомпилированного кода. Анализ может производиться как вручную, так и с помощью специальных инструментальных средств. Целью анализа является раннее выявление ошибок и потенциальных проблем в продукте. Также к статическому тестированию относится тестирования спецификации и прочей документации.

Исследовательское / ad-hoc тестирование
Простейшее определение исследовательского тестирования - это разработка и выполнения тестов в одно и то же время. Что является противоположностью сценарного подхода (с его предопределенными процедурами тестирования, неважно ручными или автоматизированными). Исследовательские тесты, в отличие от сценарных тестов, не определены заранее и не выполняются в точном соответствии с планом.

Разница между ad hoc и exploratory testing в том, что теоретически, ad hoc может провести кто угодно, а для проведения exploratory необходимо мастерство и владение определенными техниками. Обратите внимание, что определенные техники это не только техники тестирования.

Требования – это спецификация (описание) того, что должно быть реализовано.
Требования описывают то, что необходимо реализовать, без детализации технической стороны решения. Что, а не как.

Требования к требованиям:
Корректность
Недвусмысленность
Полнота набора требований
Непротиворечивость набора требований
Проверяемость (тестопригодность)
Трассируемость
Понимаемость

Жизненный цикл бага

Стадии разработки ПО - это этапы, которые проходят команды разработчиков ПО, прежде чем программа станет доступной для широко круга пользователей. Разработка ПО начинается с первоначального этапа разработки (стадия «пре-альфа») и продолжается стадиями, на которых продукт дорабатывается и модернизируется. Финальным этапом этого процесса становится выпуск на рынок окончательной версии программного обеспечения («общедоступного релиза»).

Программный продукт проходит следующие стадии:
анализ требований к проекту;
проектирование;
реализация;
тестирование продукта;
внедрение и поддержка.

Каждой стадии разработки ПО присваивается определенный порядковый номер. Также каждый этап имеет свое собственное название, которое характеризует готовность продукта на этой стадии.

Жизненный цикл разработки ПО:
Пре-альфа
Альфа
Бета
Релиз-кандидат
Релиз
Пост-релиз

Таблица принятия решений (decision table) – великолепный инструмент для упорядочения сложных бизнес требований, которые должны быть реализованы в продукте. В таблицах решений представлен набор условий, одновременное выполнение которых должно привести к определенному действию.

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

Тестирование программного обеспечения является неотъемлемой частью цикла разработки программного обеспечения.

Что такое тестирование программного обеспечения?

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

Различные наборы тест-кейсов и стратегий тестирования направлены на достижение одной общей цели - устранение багов и ошибок в коде, и обеспечения точной и оптимальной производительности программного обеспечения.

Методика тестирования

Широко используемыми методами тестирования являются модульное тестирование, интеграционное тестирование, приемочное тестирование, и тестирование системы. Программное обеспечение подвергается этим испытаниям в определенном порядке.

3) Системное тестирование

4) Приемочные испытания

В первую очередь проводится модульный тест. Как подсказывает название, это метод испытания на объектном уровне. Отдельные программные компоненты тестируются на наличие ошибок. Для этого теста требуется точное знание программы и каждого установленного модуля. Таким образом, эта проверка осуществляется программистами, а не тестерами. Для этого создаются тест-коды, которые проверяют, ведет ли программное обеспечение себя так, как задумывалось.


Отдельные модули, которые уже были подвергнуты модульному тестированию, интегрируются друг с другом, и проверяются на наличие неисправностей. Такой тип тестирования в первую очередь выявляет ошибки интерфейса. Интеграционное тестирование можно осуществлять с помощью подхода "сверху вниз", следуя архитектурному сооружению системы. Другим подходом является подход «снизу вверх», который осуществляется из нижней части потока управления.

Системное тестирование

В этом тестировании, вся система проверяется на наличие ошибок и багов. Этот тест осуществляется путем сопряжения аппаратных и программных компонентов всей системы, и затем выполняется ее проверка. Это тестирование числится под методом тестирования "черного ящика", где проверяются ожидаемые для пользователя условия работы программного обеспечения.

Приемочные испытания

Это последний тест, который проводится перед передачей программного обеспечения клиенту. Он проводится, чтобы гарантировать, что программное обеспечение, которое было разработано отвечает всем требованиям заказчика. Существует два типа приемо-сдаточных испытаний - то, которое осуществляется членами команды разработчиков, известно, как внутреннее приемочное тестирования (Альфа-тестирование), а другое, которое проводится заказчиком, известно, как внешнее приемочное тестирования.

Если тестирование проводится с помощью предполагаемых клиентов, оно называется приемочными испытаниями клиента. В случае если тестирование проводится конечным пользователем программного обеспечения, оно известно, как приемочное тестирование (бета-тестирование).

Есть несколько основных методов тестирования, которые формируют часть режима тестирования программного обеспечения. Эти тесты обычно считаются самодостаточными в поиске ошибок и багов во всей системе.

Тестирование методом черного ящика

Тестирование методом черного ящика осуществляется без каких-либо знаний внутренней работы системы. Тестер будет стимулировать программное обеспечение для пользовательской среды, предоставляя различные входы и тестируя сгенерированные выходы. Этот тест также известен как Black-box, closed-box тестирование или функциональное тестирование.

Тестирование методом белого ящика

Тестирование методом "Белого ящика", в отличие от "черного ящика", учитывает внутреннее функционирование и логику работы кода. Для выполнения этого теста, тестер должен иметь знания кода, чтобы узнать точную часть кода, имеющую ошибки. Этот тест также известен как White-box, Open-Box или Glass box тестирование.

Тестирование методом серого ящика

Тестирование методом серого ящика или Gray box тестирование, это что-то среднее между White Box и Black Box тестированием, где тестер обладает лишь общими знаниями данного продукта, необходимыми для выполнения теста. Эта проверка осуществляется посредством документации и схемы информационных потоков. Тестирование проводится конечным пользователем, или пользователям, которые представляются как конечные.

Нефункциональные тесты

Безопасность приложения является одной из главных задач разработчика. Тестирование безопасности проверяет программное обеспечение на обеспечение конфиденциальности, целостности, аутентификации, доступности и безотказности. Индивидуальные испытания проводятся в целях предотвращения несанкционированного доступа в программный код.

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


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


Как подсказывает название, эта методика тестирования проверяет объем кода или ресурсов, которые используются программой при выполнении одной операции.

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

Тесты в процессе разработки программного обеспечения

Каскадная модель использует подход "сверху-вниз", независимо от того, используется ли она для разработки программного обеспечения или для тестирования.

Основными шагами, участвующими в данной методике тестирования программного обеспечения, являются:

  • Анализ потребностей
  • Тест дизайна
  • Тест реализации
  • Тестирование, отладка и проверка кода или продукта
  • Внедрение и обслуживание

В этой методике, вы переходите к следующему шагу только после того, как вы завершили предыдущий. В модели используется не-итерационный подход. Основным преимуществом данной методики является ее упрощенный, систематический и ортодоксальный подход. Тем не менее, она имеет много недостатков, так как баги и ошибки в коде не будут обнаружены до этапа тестирования. Зачастую это может привести к потере времени, денег, и других ценных ресурсов.

Agile Model

Эта методика основана на избирательном сочетании последовательного и итеративного подхода, в дополнение к довольно большому разнообразию новых методов развития. Быстрое и поступательное развитие является одним из ключевых принципов этой методологии. Акцент делается на получение быстрых, практичных, и видимых выходов. Непрерывное взаимодействие с клиентами и участие является неотъемлемой частью всего процесса разработки.

Rapid Application Development (RAD). Методология быстрой разработки приложений

Название говорит само за себя. В этом случае методология принимает стремительный эволюционный подход, используя принцип компонентной конструкции. После понимания различных требований данного проекта, готовится быстрый прототип, а затем сравнивается с ожидаемым набором выходных условий и стандартов. Необходимые изменения и модификации вносятся после совместного обсуждения с заказчиком или группой разработчиков (в контексте тестирования программного обеспечения).

Хотя этот подход имеет свою долю преимуществ, он может быть неподходящим, если проект большой, сложный, или имеет чрезвычайно динамический характер, в котором требования постоянно меняются.

Спиральная модель

Как видно из названия, спиральная модель основана на подходе, в котором есть целый ряд циклов (или спиралей) из всех последовательных шагов в каскадной модели. После того, как начальный цикл будет завершена, выполняется тщательный анализ и обзор достигнутого продукта или выхода. Если выход не соответствует указанным требованиям или ожидаемым стандартам, производится второй цикл, и так далее.

Rational Unified Process (RUP). Рациональный унифицированный процесс

Методика RUP также похожа на спиральную модель, в том смысле, что вся процедура тестирования разбивается на несколько циклов. Каждый цикл состоит из четырех этапов - создание, разработка, строительство, и переход. В конце каждого цикла продукт/выход пересматривается, и далее цикл (состоящий из тех же четырех фаз) следует при необходимости.

Применение информационных технологий растет с каждым днем, также и важность правильного тестирования программного обеспечения выросло в разы. Многие фирмы содержат для этого штат специальных команд, возможности которых находятся на уровне разработчиков.

В нашей группе не один раз обсуждалась разработка через тестирование (test-driven development), и каждый раз в комментариях были в основном положительные отзывы от тех, кто применял эту методологию. Для тех, кто пропустил, собрали все доводы «за» в одной статье.

Напомните, что же вообще такое ваше «Test-Drive-Development»?

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

Звучит как-то странно. А это точно эффективно?

Судя по всему, да. Во-первых, это позволяет чётче понять, что, собственно, нужно писать. Есть условие, которое должно выполняться после работы кода - и точка. Сами тесты должны формироваться на основе технического задания. Если в результате написания тестов они начинают противоречить сами себе – это повод пересмотреть ТЗ.

Во-вторых, в результате разделения задач на менее объёмные подзадачи, код становится заметно проще и удобочитаемее. В идеале на один тест должно приходиться одно утверждение (assert). К тому же плохой в оформлении код (например, использующий глобальные переменные или синглтоны) обычно так же сложен в тестировании, что стимулирует разработчика его не писать.

В-третьих, сильно упрощается поддержка кода. Если в результате внесения новой функциональности или изменения старой какой-то участок кода начинает работать некорректно, это будет мгновенно выявлено. Вносить в код изменения гораздо легче, когда он разбит на модули (а TDD требует модульности программ). Инспектировать код, написанный по методологии TDD гораздо проще – каждый коммит выполняется для реализации чёткой задачи, которая будет отражена в комментарии к нему.

Но мне кажется, что писать как обычно гораздо быстрее

Да, действительно, поначалу применение TDD будет отнимать лишнее время. Однако, это скорее дело привычки – со временем вы привыкнете писать сперва тесты, а лишь затем код и, возможно, будете даже выигрывать во времени, ведь процесс разработки будет чётко структурирован, вам придётся сначала решить вопрос «Что писать?», а лишь потом «Как писать?». К тому же, потратив время сейчас, вы выиграете время в будущем, сильно облегчив себе поддержку продукта.

Всегда ли имеет смысл использовать TDD?

Разумеется, нет. TDD не панацея. Например, если разработка представляет из себя последовательность экспериментов, когда нет чёткой уверенности в том, что именно необходимо в итоге, написание тестов станет скорее грузом, который тянет команду назад.

С чего же начать?

По разработке с упором на тестирование есть отличная книга Кента Бека –

ВВЕДЕНИЕ

В связи с модернизацией современного высшего образования , с введением ФГОС третьего поколения, возрастают требования к повышению качества педагогического контроля, ведется поиск его лучших форм и методов, его экономичности, оптимизации. Оценка качества образования также на сегодняшней день является наиболее приоритетной проблемой в образовательной деятельности . Новый стандарт предполагает также переход на систему контроля и оценки знаний слушателей, в связи с этим большое значение приобретает измерение результатов усвоения программного материала.

Мониторинг качества образовательной системы предполагает, прежде всего, регулярный сбор и обработку информации об уровне профессиональных знаний, умений студентов. Одним из основных инструментов оценки качества уровня обученности студентов является тестирование вообще и компьютерное тестирование в частности, позволяющие дать достаточно объективную нормативно-ориентированную оценку учебных достижений обучающихся.

Каким содержанием наполнено понятие «педагогический тест»? Какие классификации педагогических тестов существуют, и какие критерии применятся для оценки качества педагогических тестов? В чем преимущество тестовых форм контроля в процессе обучения? Что понимается под термином «тестовое задание», и какие правила необходимо соблюдать при составлении тестовых заданий? Как составить тестирование обучающихся при подготовке к внутреннему тестированию в рамках внутривузовской проверки качества профессиональной подготовки? Ответы на эти вопросы, а также конкретные образцы тестовых заданий разного вида представлены в данном учебно-методическом издании.


ПЕДАГОГИЧЕСКИЙ ТЕСТ КАК КОНТРОЛЬНО-ИЗМЕРИТЕЛЬНЫЙ МАТЕРИАЛ

Педагогический тест является наиболее распространенным контрольно-измерительным материалом в современном образовательном процессе в вузе. Педагогический тест – это совокупность заданий, отобранных на основе научных приемов для педагогического измерения в тех или иных целях.

Педагогический тест рассматривается как система, как упорядоченное множество тестовых заданий. Задания – это те элементы, «кирпичики» из которых составляется педагогический тест.

Почему именно тестирование становится все более массовым явлением в процессе педагогического оценивания?

Опыт использования тестов в качестве инструмента для оценивания позволяет выделить многие его преимущества, в частности, тест:

· это более качественный и объективный способ оценивания, что достигается путем стандартизации процедуры проведения (отсутствие субъективной оценки на всех этапах тестирования) и стандартизации заданий;

· более емкий инструмент – показатели тестов ориентированы на измерение степени, определение уровня усвоения ключевых понятий, тем и разделов учебной программы , умений, навыков, а не на констатацию наличия у обучающихся определенной совокупности усвоенных знаний;

· позволяют включить в экзаменационную работу гораздо большее количество заданий;

· это более «мягкий» инструмент, они ставят всех испытуемых в равные условия, используя единую процедуру и единые критерии оценки, что приводит к снижению нервного напряжения;

· широкий инструмент – и с точки зрения интервала оценивания;

· более эффективен с экономической точки зрения, как при тестировании основные затраты приходятся на составление качественного инструментария.

Было бы конечно большой ошибкой считать, что педагогическое тестирование свободно от недостатков. Применение педагогических тестов – эта та область знаний и умений, которая поддается формализации. Но далеко не все учебные дисциплины или их разделы формализуемы.

К недостаткам тестов следует отнести то, что тестовый контроль лишает возможности слушателей самостоятельно формулировать ответы, отсутствует возможность проявить свою индивидуальность, творчество.

Но самый большой недостаток – это сложность разработки хороших тестовых заданий, хотя на первый взгляд кажется, что с этим никаких трудностей быть не должно, ведь тестовые задания разрабатываются преподавателями, хорошо знающими свой предмет. На самом деле разработка педагогических тестов требует высокой педагогической квалификации, научной компетенции и большого методического опыта составления тестов преподавателем. В этой связи необходимо самое пристальное внимание уделять повышению качества тестовых заданий.

При проведении тестирования учитываются три критерия качества теста: надежность, валидность и объективность.

Надежность теста - критерий, отражающий точность диагностических измерений, а также устойчивость результатов теста к действию посторонних случайных факторов. Надежность педагогического теста позволяет при его применении в разных группах обучающихся с близким уровнем подготовки получать примерно одинаковые результаты. Результат педагогического тестирования обычно подвержен влиянию большого количества неучитываемых факторов (например, эмоционального состояния и утомления, уровня мотивированности тестируемых и др.). Любое изменение ситуации тестирования усиливает влияние одних и ослабляет воздействие других факторов на результат теста.


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

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

Важнейшим средством повышения надежности педагогических тестов является стандартизация процедуры тестирования. При строгой регламентации процедуры тестирования (обстановка и условия работы слушателей, характер инструкции, временные ограничения, способы и особенности контакта со слушателями, порядок предъявления тестовых задач и т. д.) существенно уменьшается дисперсия ошибки и повышается надежность теста. При прочих равных условиях надежность теста зависит от числа заданий (длины теста) - чем длиннее тест, тем он надежнее.

Валидность теста - это критерий, который определяет, что тест измеряет и насколько хорошо он это делает. В понятии валидности отражается идея соответствия педагогического тестирования его цели. Интуитивно все понимают, что одно и то же можно проверять по разному. Отсюда возникает вопрос поиска наиболее подходящего (валидного) средства, полнее, чем другие, удовлетворяющего требованиям качества проверки.

В педагогических тестах наиболее важным типом валидности является валидность по содержанию. При проверке содержательной валидности речь идет об определении степени соответствия содержания тестовых заданий содержанию учебного предмета, успешность усвоения которого тестируется, то есть решается вопрос о том, в какой степени задачи данного диагностического контроля успеваемости репрезентативны для содержания учебной программы.

Для обеспечения валидности педагогического теста требуется систематическая проверка того, насколько задания теста охватывают все главные аспекты учебной программы и в правильной пропорции. Тест легко перенасытить теми аспектами учебной программы, по которым легче составить объективные задания. Поэтому рассматриваемое содержание следует фиксировать заранее, а не после того как тест уже составлен. Правильно построенные педагогические тесты должны соответствовать не только предмету обучения, но и его задачам. Содержание, следовательно, необходимо определять достаточно широко, включая в него помимо знания фактического материала такие важнейшие цели обучения, как применение изученных принципов и интерпретацию данных. Валидность также обеспечивается распределением тестовых заданий различной трудности пропорционально уровню трудности учебного материала.

Валидность по содержанию закладывается в тест уже при отборе соответствующих заданий. Для педагогических тестов подготовке их заданий предшествует полная систематизированная проверка соответствующих учебников и учебных программ, а также консультации со специалистами по данному предмету. На основе собранной таким путем информации составляется спецификация теста для тех, кто будет составлять задания. В спецификации указываются тестируемые области содержания (темы), задачи (процессы) обучения, а также относительное значение каждой темы и процесса. На этой основе по каждой теме устанавливается число заданий различных типов. (Более подробно вопрос составления спецификации будет рассмотрен ниже).

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

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

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

Педагогический аспект повышения объективности педагогического тестирования проявляется в использовании стандартных тестовых программ, технических средств контроля, в первую очередь использование компьютерных технологий в организации проведения педагогического тестирования.

Этический аспект объективности охватывает широкую область морального регулирования. Результаты педагогического теста могут оказаться полностью или частично неадекватными поставленной цели, если допускается списывание, подсказки со стороны слушателей, репетиторство (но не всякое, а «натаскивание»), снисходительность или, наоборот, чрезмерная требовательность преподавателей.

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

ЭТАПЫ СОСТАВЛЕНИЯ И ОБЩИЕ ТРЕБОВАНИЯ К РАЗРАБОТКЕ ТЕСТА

В данном разделе представлены основные этапы составления теста.

В разработке педагогических тестов можно выделить три этапа: планирование, написание заданий и анализ заданий (см. Рис. 1).

Перед разработкой теста необходимо четко иметь представление о требованиях к знаниям, навыкам и умениям обучающихся по данной учебной дисциплине. Эти требования определены в соответствующих Государственных образовательных стандартах, предметных квалификационных характеристиках и типовых учебных программах. Первый шаг в планировании теста - это анализ данных документов. Задания теста должны в полной мере выявить степень овладения требуемыми знаниями, навыками и умениями.

Составитель теста, начинающий с написания задания, скорее всего, создаст узконаправленный тест. Без предварительного плана некоторые темы изучаемого предмета могут занять слишком много места, в то время как другие останутся незатронутыми.

Выбор типа тестового задания


Рисунок 1. Этапы разработки теста

Во избежание несбалансированности и диспропорции , охватываемых тестом тем составлению заданий должна предшествовать разработка его спецификации.

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

· номера заданий и их принадлежность к субтестам;

· направленность заданий;

· сложность, трудоемкость, вес заданий;

· какую из характеристик каждое из заданий конкретно диагностирует.

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

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

а) простого воспроизведения знаний, анализа и сравнения данных. Постановка таких вопросов в заданиях позволяет проверить усвоение слушателями материала на уровне запоминания, тренирует память;

б) анализа признаков понятия. При этом выявляется умение обучаемых находить общее и специфическое в изучаемом материале, отделять существенные признаки от несущественных, родовые от видовых, способствует развитию аналитического мышления;

в) умения распознавать схемы, рисунки;

г) понимания функций, выполняемых различными органами (звеньями, приборами, устройствами и т. п.), и процессов взаимодействия между этими органами. Вопросы такого типа позволяют проверить умение слушателя вскрывать определенные причинно-следственные связи и отношения, оценивать роль и значение данного органа для процессов, происходящих во всей системе;

д) приведения в логическую последовательность элементов множества, расположенных в беспорядке, т. е. умения решать определенного класса задачи, требующие обнаружить последовательность расположения элементов в информационном ряде объектов, тактических приемов, например, в следственном действии либо оперативно-розыскном мероприятии;

е) творческого подхода к рассматриваемым проблемам и вопросам, умения применять полученные знания в условиях той или иной ситуации.

При создании тестов для проверки остаточных знаний на основании ФГОС ВПО по соответствующей дисциплине или для проверки итоговых знаний студента на основании программы дисциплины прежде всего определяется область содержания теста и цели тестирования. План теста для промежуточного контроля знаний должен охватывать знания, умения и навыки по одной или нескольким дидактическим единицам, для итоговой аттестации по всем дидактическим единицам дисциплины в соответствии с программой дисциплины, для проверки остаточных знаний по всем дидактическим единицам дисциплины в соответствии с ФГОСом по специальности.

Преподавателю следует ориентироваться на следующие принципы отбора содержания тестовых заданий для тестов:

2. Необходимо включение в тесты только наиболее важных, базовых знаний, выражающих сущность, содержание, законы и закономерности рассматриваемых явлений. Все спорные точки зрения, допустимые в научном споре, следует исключить из тестовых заданий.

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

Эксперты, определенные на кафедре, оценивают соответствие заданий области содержания и целям тестирования. Проводится внутреннее пробное тестирование преподавателями кафедры. Осуществляется предварительная корректировка теста. Определяется время тестирования студентов. Рекомендуемая продолжительность ответа на тестовое задание составляет 1,5 минуты.

На основании анализа статистических параметров по каждому заданию и тесту в целом производится повторная корректировка теста - удаляются неудачные задания, если необходимо - составляются новые.

Производится выбор стандартов оценивания экспертными и эмпирическими методами. Выполняется оценка надежности теста и содержательной валидности (соответствия заданий содержанию дидактических единиц). Составляется окончательный вариант теста и его параллельных форм. Тиражируется сам тест и связанный с ним материал (если используется бумажный вариант тестирования). При подготовке теста к компьютерному тестированию готовится бумажный и электронный вариант теста и заносится в тестовую оболочку программистом компьютерного класса.

ВИДЫ ТЕСТОВЫХ ЗАДАНИЙ

Существует ряд требований к тесту организационного характера:

Тестирование осуществляется главным образом через программированный контроль, никому не дается преимуществ, все отвечают на одни и те же вопросы в одних и тех же условиях;

Оценка результатов производится по ранее разработанной шкале;

Применяются необходимые меры, предотвращающие искажение результатов (списывание, подсказку и утечку информации о содержании тестов)

При разработке теста целесообразно использовать различные виды тестовых заданий. В частности:

Задания с выбором одного правильного ответа (ВО)

Задания с выбором нескольких правильных ответов (MB)

Задания на установление правильной последовательности (УП)

Задания на установление соответствия (УС)

Задания с кратким ответом (КО)

Общие требования к тестовым заданиям разного типа

Текст задания должен исключать всякую двусмысленность и неясность формулировок.

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

В задании не используются слова, вызывающие различное понимание у испытуемых, а также слова, являющиеся подсказкой, например, «иногда», «часто», «всегда», «все», «никогда».

В заданиях, носящих составной характер, необходимо обеспечить такую последовательность, чтобы правильность выполнения одного задания не зависела от правильности выполнения другого задания данной группы.

В тексте задания исключается двойное отрицание.

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

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

Требования к дистракторам:

По возможности, не следует делать ответы длинными;

Одно и то же слово (или словосочетание, или однокоренное слово) не должно находиться в тексте задания и правильном ответе;

Все ответы должны быть подобными (аналогичными, похожими), это касается и их внешнего вида, и грамматической структуры.

В вариантах ответа на задания желательна краткость;

Ответы на основу задания должны быть сформулированы достаточно просто, чтобы были понятны существенные различия между ними;

Каждый дистрактор должен быть правдоподобным, внушающим доверие, вполне убедительным и привлекательным для экзаменующихся;

Правильный ответ должен быть ясен, краток, правилен и свободен от подсказок (как внутри текста задания, так и вне его);

Ответы должны быть одинаковы по длине (хотя бы приблизительно), не следует формулировать правильный ответ заметно длиннее или короче, чем дистракторы;

В дистракторах не следует использовать слова или технические термины, которые экзаменующийся не может или не должен знать;

При формулировке дистракторов не следует использовать выражения: «ни один из перечисленных», «все перечисленные» и т. д., так как они способствуют угадыванию правильного ответа;

Из дистракторов, как правило, исключаются все повторяющиеся слова путем ввода их в основной текст задания;

Все ответы должны быть грамматически согласованными с основной частью задания;

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

Задания с выбором одного верного ответа (ВО)

Общие требования

Формулировка основной части задания, должна быть законченной.

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

В заданиях базового уровня не должно требоваться выбрать один НЕПРАВИЛЬНЫЙ ответ при наличии нескольких правильных.

Из текста задания исключаются все словесные ассоциации, способствующие выбору правильного ответа с помощью догадки.

Если имеется задание с отрицаниями, то частицу НЕ или слово, выражающее отрицание, необходимо выделить в тексте (жирным текстом с подчеркиванием).

Задания должны иметь одинаково правдоподобные дистракторы (ответы), одинаково привлекательные для выбора.

Исключаются ответы, вытекающие один из другого или дополняющие друг друга.

Задания с выбором одного верного ответа (ВО)

Примеры заданий:

Функция живого вещества, связанная с преобразованием физико-химических параметров среды, называется...

A. средообразующей

D. концентрационной.

Различные типы заданий с выбором ответа

Примеры заданий ВО в повествовательной форме (в виде суждений)

Аппаратом сухой, инерционной очистки газов от пыли является...

2)скруббер

3)волокнистый фильтр

4)электрофильтр

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

1)мониторингом

2)аудитом

3)страхованием

4) нормированием.

Задания на отрицание

В архейскую эру НЕ существовало...

A. беспозвоночных животных

C. анаэробных бактерий

Примеры заданий с рисунком

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

На представленном рисунке показана схема...

2)очистки газовых выбросов ТЭС

Примеры заданий формы множественный выбор «два из пяти» ( MB ):

К цветковым растениям относятся...

A. одуванчик лекарственный

B. рябина обыкновенная

C. ель европейская

D. сосна обыкновенная

E. плаун булавовидный

Примеры заданий формы множественный выбор «три из шести»(МВ):

выделял такие виды веществ в биосфере , как...

3) биоксное

4)твердое

5)мертвое

6)автотрофное

Пример задания формы установление последовательности (УП):

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

1)пожарище

2)кустарник

3)смешанный лес

Установите правильный порядок действий при выделении хлоропластов методом центрифугирования...

1)поставить центрифужные пробирки в центрифугу

2)измельчить лист растения ножницами

3)растереть растительную навеску в ступке при помощи пестика

4)уравновесить центрифужные пробирки

5)включить центрифугу на определенное время и определенное количество оборотов.

Задания на установление соответствия (УС)

Общие требования

Задания контролируют умение установить соответствие между объектами или процессами и описанием их свойств и признаков. Задания на установление однозначного или множественного соответствия начинаются со слов: «Установите соответствие...».

Задание формулируется так, чтобы содержание можно было выразить в виде двух множеств с соответствующими названиями. Элементы первого столбца обозначаются цифрами и располагаются слева, а элементы второго обозначаются буквами русского алфавита и располагаются справа. Для каждого столбца вводится определенное название, обобщающее все элементы столбца. Название столбца записывается заглавными буквами. Элементы столбцов должны быть выбраны по одному основанию. Для заданий на однозначное соответствие необходимо, чтобы второй столбец содержал не менее одного дистрактора.

Для всех учебных предметов используется одинаковый формат ответов, представленный ниже.

Пример задания формы УС:

Установите соответствие между группами растений по отношению к свету и признаками растений:

ПРИЗНАКИ ЭКОЛОГИЧЕСКИЕ

ГРУППЫ РАСТЕНИЙ

1) Имеют темно-зеленый цвет; А) Светолюбивые

2) Не выносят малейшего затенения; Б) Тенелюбивые.

3) Процесс фотосинтеза преобладает над дыханием;

4) Не выносят сильной освещенности;

5) Растут под пологом леса;

6) Обитают на освещенных местах.

Задания открытой формы

Общие требования

В заданиях открытой формы не используются готовые варианты ответов. В них испытуемому нужно дополнить недостающее слово (группу слов, формулу, число, знак и др.), которое свидетельствует о его знании.

Существует большое разнообразие типов заданий в открытой форме.

Задания открытой формы подразделяются на задания с коротким ответом и задания с развернутым ответом или эссе.

В практике массового педагогического тестирования в основном применяются следующие модификации заданий открытой формы:

Задания с коротким ответом (КО);

Задания на завершение утверждения (ЗУ);

Задания на заполнение пробела (ЗП);

Задания на завершение (или на конструирование) графического объекта (диаграммы, графика, схемы).

Примеры заданий формы КО:

1). Если ПДК нитратов для человека составляет 3,05 мг/кг в сутки, то для человека массой 68 кг допустимо поступление в организм этих веществ до___ мг.

2). Если норматив платы за выброс 1 тонны фенола в атмосферу в пределах установленных лимитов составляет 3,415 тыс. руб., то при выбросе предприятием 22 тонн данного загрязняющего вещества, выплаты составят___ тыс. рублей.

Задания на завершение утверждения

Представленный ниже график иллюстрирует закон __________________.

Изображенная на рисунке модель иллюстрирует закон ___________. ­­­­­­­­­ ­­­­­­­

ТИПИЧНЫЕ ОШИБКИ, ДОПУСКАЕМЫЕ ПРИ СОСТАВЛЕНИИ ВОПРОСОВ К ТЕСТУ

При составлении тестовых заданий разработчикам следует не только придерживаться определенных правил к формулировке заданий, правильных ответов и дистракторов, но и избегать основных, наиболее типичных неточностей и ошибок при их написании. Наиболее часто встречаются следующие нарушения требований и определенных критериев при написании тестовых заданий.

Следует избегать составлять задания, которые проверяют больше чем одну идею, проблему, концепцию. При этом в правильном ответе и дистракторах не должно содержаться разное количество элементов ответа:

Важнейшими экологическими последствиями глобального загрязнения атмосферы являются...

1) кислотные осадки и парниковый эффект

2)демографические параметры

3)извержения вулканов

4)естественные сукцессии

В правильном ответе и дистракторах содержится разное количество элементов ответа: В ходе световой фазы фотосинтеза происходит...

1) фотолиз воды и выделение свободного кислорода

2)фиксация углекислого газа

3)использование энергии АТФ

4)синтез глюкозы

К липидам относятся...

1) стероиды, терпены, воска и фосфолипиды

2)только стероиды

3)только терпены

4) только фосфолипиды.

Из дистракторов, как правило, исключаются все повторяющиеся слова путем ввода их в основной текст задания, например:

Неправильно Правильно

Области концентрации живого Области концентрации живого

вещества на границе двух сред вещества на границе двух сред

обитания обитания

назвал… назвал ________жизни.

1) узлами жизни 1) узлами

2)очагами жизни 2) очагами

3)рубежами жизни 3) рубежами

4)точками жизни 4) точками

Часть ответа лучше вынести в вопрос, например:
Неправильно Правильно

Для изучения тонкой структуры Для изучения тонкой структуры

клеточных органелл наиболее клеточных органелл наиболее эффективным оказался эффективным оказался метод

метод … ………. микроскопии.

1) электронной просвечивающей 1) электронной просвечивающей

микроскопии 2) электронной сканирующей

2)электронной сканирующей 3) флуоресцентной

микроскопии 4)световой

3)флуоресцентной микроскопии

4)световой микроскопии

Все ответы должны быть грамматически согласованными с основной частью задания. Например, наблюдается несоответствие родов или падежей:

Круговорот веществ, движущей силой которого является деятельность живых организмов, называется...

1)биологическим

2)большом

3)геологический

4) антропогенным.

Не все иностранные фамилии можно склонять по падежам.

Неправильно Правильно

Роль микроорганизмов в Роль микроорганизмов в питании растений была питании растений была

выявлена в опытах, проведенных… выявлена в опытах, которые

4)Саксом Ю 4)

Все ответы должны быть грамматически согласованными с основной частью задания. Например, может наблюдаться несоответствие чисел (единственное и множественное):

Неправильно Правильно

Пространство, на котором Пространство, на котором

популяция или вид в целом популяция или вид в целом

встречается в течение всей встречается в течение всей

своей жизнедеятельности, своей жизнедеятельности,

называется... называет(ют)ся...

1)ареалом 1) ареалом

2)площадью 2) площадью

3)зонами 3) зонами

4)территориями 4) территориями

Не допускается использование словосочетаний: ни один из перечисленных выше; все перечисленные; все, кроме...

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

1)активный путь, пассивный путь, избегание неблагоприятных воздействий

2) все перечисленные, кроме активного пути

3) только активный путь

4) ни один из перечисленных вариантов ответа не верен.

Ответы должны быть одинаковы по длине (хотя бы приблизительно),не следует формулировать правильный ответ заметно длиннее или короче, чем дистракторы. Следовательно, правильный ответ не должен отличаться внешне по длине от дистракторов:

Для защиты атмосферы от загрязнения проводят...

1) очистку выбросов предприятий от вредных примесей с помощью газоулавливающих средств

2)интродукцию растений

3)рекультивацию земель

4)мелиоративные мероприятия

Не следует в качестве дистракторов приводить понятия, явно не имеющие отношения к предмету тестирования:

Основы конституционного строя Российской Федерации

Правовой статус личности в Российской Федерации

Органы государственной власти в Российской Федерации

Основы гражданского права Российской Федерации

Граждане и юридические лица как субъекты гражданского права

Право собственности

Обязательства и договоры

Наследственное право Российской Федерации

Система наказаний по уголовному праву

Бумажная копия теста должна быть обязательно подписана автором (авторами) тестового материала с указанием даты составления и передачи, листы скреплены и пронумерованы.

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

«Компьютерные» педагогические тесты имеют свои особенности, которые необходимо учитывать при их разработке. Анализ информации на экране монитора компьютера часто бывает затруднен из-за неправильной подачи материала. Хотя именно компьютеризованное тестирование имеет свои преимущества и перспективы применения в образовании. Особенная роль здесь принадлежит компьютерно-индивидуальному тестированию, когда каждому испытуемому предъявляется уникальный набор заданий.

Возможности компьютерных средств позволяют сочетать звуковые и зрительные формы предъявления тестовых заданий. Компьютерные тесты должны быть адаптированы к реальному учебному процессу. Одно из главных требований к компьютерным тестам - многовариантность. Многовариантность должна быть двух типов: во-первых, по данным заданий, во-вторых, по порядку их предъявления. Реализация этого требования снимает сразу две организационные проблемы: списывание и запоминание ответов.

Достоинства компьютерного тестирования:

объективность тестирования - персональный компьютер «беспристрастен» при предъявлении тестовых заданий и подсчете результатов их выполнения.

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

Удобство реализации процедур индивидуально-ориентированного тестирования.

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

Недостаток компьютерного тестирования:

Необходимость минимальных навыков работы на компьютере
тестируемого.

В вузах существуют тестовые оболочки, куда заносятся вопросы и варианты ответов тестовых заданий (например «iTest», «My test» и др.). При подготовке компьютерного тестирования следует учитывать следующую (рекомендуемую) схему взаимодействия подразделений вуза (см. рис. 2).

43">



Рисунок 2. Схема взаимодействия подразделений в разработке и реализации компьютерного теста

Сектор качества образования УМО обеспечивает централизованное и конфиденциальное хранение тестовых заданий по учебным дисциплинам.

При оценке выполнения теста следует исходить из следующих рекомендаций:

Оценка «удовлетворительно» ставится, если студент ответил на от 55 до 70% вопросов.

Оценка «хорошо» ставится, если студент получил от 71 до 85%.

Оценка «отлично» ставится, если студент получил 86% и более правильных ответов.

1. Аванесов, B. C. Композиция тестовых заданий/ B. C. Аванесов. - М.: АДЕПТ, 1998.-216 с.

2. Воскресенская, качества подготовки студентов по дисциплине «Физиология растений» на основе результатов Интернет-экзамена/ , /Материалы Всероссийской конференции «Преподавание современной физиологии растений в университетах и вузах страны: проблемы и решения». - М., 2008.

3. Геворкян, Е. Н., Комплексная оценка высших учебных заведений/ , М. В.Петропавловский . - М.: Центр государственной аккредитации , 20с.

4. Ефремова, тестовые технологии в образовании/ . - Ростов-на-Дону: Издательский центр ДГТУ, 20с.

5. Киселева, определения уровня подготовки студентов по результатам аттестационных педагогических измерений/ , В. Г Наводнов. - Йошкар-Ола: Центр государственной аккредитации, 20с.

6. Клайн, П. Справочное руководство по конструированию тестов/ П. Клайн. - Киев, 1994.-238 с.

7. Майоров, и практика создания тестов для системы образования. / . - М: Народное образование, 20с.

8. Масленников, уровня обученное™ студентов в целях аттестации образовательного учреждения профессионального образования : Учебное пособие/, . - М.: Логос, 20с.

9. Мельников, использования и разработки тестов и обучающих программ: Методическое пособие / . - Домодедово: ВИПК МВД России, 19с.

10. Ю. Михайлычев, тестология / . - М.: Народное образование, 20с.

11. П. Морев, информационные технологии . Часть 2. Педагогические измерения: Учебное пособие/ . - Владивосток: Изд-во Дальневост. ун-та, 20с.

12. Переверзев, -ориентированное педагогическое тестирование: Учеб. Пособие/ . - М.: Логос, 20с.

1З. Родионов, и тесты в образовании / Б. У Родионов, . - М.: Б. и., 19с.

14.Н. Челышкова, и практика конструирования педагогических тестов: Учебное пособие/ . - М.: Исследовательский центр проблем качества подготовки специалистов, 20с.

Приложение 1

Классификация тестов

1. По процедуре создания:

Стандартизованные (в образовании, для целей итоговой аттестации);

Не стандартизованные.

2. По средствам предъявления:

Бланковые;

Предметные (манипулируем материальными объектами);

Аппаратурные (используются устройства для изучения особенностей внимания, восприятия, памяти, мышления);

Компьютерные.

В рамках компьютерного тестирования B. C. Аванесов предлагает адаптивные тесты - задания, в которых предъявляются по одному, в зависимости от ответа испытуемого на предыдущий вопрос.

3. По направленности:

Тесты интеллекта;

Личностные тесты;

Тесты достижений.

4. По характеру действий:

Вербальные (с использованием умственных действий);

Невербальные (связанные с практическим манипулированием предметов).

5. По ведущей ориентации:

Тесты скорости (содержат простые задачи; время решения ограничено);

Тесты мощности или результативности (содержат трудные задачи, время решения не ограничено, или мягко лимитировано);

Смешанные тесты (задачи различного уровня сложности, от самых простых до самых сложных, время испытания ограничено, но достаточно для решения большинства задач). Эти тесты наиболее часто применяются на практике, к ним относятся большинство тестов учебных достижений.

6. По степени однородности задач:

Гомогенные (задачи, сходные по характеру, но различающиеся конкретным содержанием);

Гетерогенные (задания отличаются и по характеру, и по содержанию).

7. По объективности оценивания:

Объективные (в процессе обработки результатов тестирования не предусматривается использование субъективных толкований тестирующим);

Проективные тесты (допускается чрезвычайно большое разнообразие ответов и проявление определенной субъективности при их толковании тестирующим.

8. По специализации:

Широкоориентированные (для тестов в системе образовании), позволяющие оценить эффективность процесса обучения, степень освоения учащимися системы знаний, умений и навыков в ходе учебного процесса;

Узкоориентированные, направленные на выявление достижений учащихся в процессе освоения отдельных предметов, отдельных тем и т. д.

9. По целям использования

Предварительный определяющий тест (определяет знания в начале обучения, затрагивает минимум знаний по теме обучения);

Тест прогресса, достигнутого в процессе обучения, формирующий тест (затрагивает ограниченный сегмент обучения, раздел или главу, состоит из серии отдельных тестовых вопросов , всесторонне охватывающих ограниченную область обучения). Пример, обучающие тесты. Ученику даются конкретные инструкции для исправления обнаруженных ошибок;

Диагностический тест (содержит большое число вопросов, имеющих отношение к конкретной тестируемой области). Цель теста - определение трудностей обучения.

Суммирующий тест (используется для оценки широкого диапазона результатов обучения, ожидаемого в конце учебного процесса, содержит вопросы, представляющие более высокий уровень сложности, чем другие виды тестов).

10. По широте использования (только для тестов в системе образования):

Для использования преподавателем;

Для использования группой преподавателей или администрацией образовательного
учреждения;

Для целей отбора и формирования групп;

Для аттестации обучающихся.

11. По форме:

Тесты закрытого типа (задания с выбором верного ответа (или нескольких верных) из набора предлагаемых;

Тесты открытого типа (ввод предполагаемого ответа на задание самим тестируемым)

Приложение 2

Образец оформления титульного листа теста по дисциплине

Приложение 3

Образец оформления первого листа тестовых заданий

ОБЩИЕ СВЕДЕНИЯ О ТЕСТОВЫХ ЗАДАНИЯХ

2. Название цикла дисциплин учебного плана_ ________________________

3. Дисциплина (или дисциплины комплексного задания) __________________

4.Цель контроля ____________________________________________________

5.Общее количество тестовых заданий _________________________________

7.Форма (ы) заданий

Открытая_________________________________________________________

Закрытая (с выбором одного или нескольких заключений) _______________

На установление правильной последовательности ______________________

На установление соответствия _______________________________________

На конструирование и др. ___________________________________________

8. Время, на которое рассчитан тест____________________________________

9.Уровень сложности:

Легкие __________________________________________________________

Среднейтрудности_________________________________________________
- трудные _________________________________________________________

10. Критерии оценки:

Оценка 3 (удовлетворительно) 25-49 баллов ________% правильных ответов

Оценка 4 (хорошо) 50-74 баллов ________% правильных ответов

Оценка 5 (отлично) 75-100 баллов_______% правильных ответов

10.Кафедра(ы) – разработчик (и) контролирующих материалов ________________

Тестовые задания и ключи к ним прилагаются.