В разработке программного обеспечения тестирование и разработка являются двумя основными связями. Эти два звена взаимозависимы и влияют друг на друга, составляя весь жизненный цикл программных продуктов. Однако в последние годы, с ростом популярности передовых моделей разработки, таких как гибкая разработка, непрерывная интеграция и непрерывная доставка, в наше поле зрения постепенно вошла новая роль — инженер по разработке тестов. Их работа, похоже, включает в себя как тестирование, так и разработку. Итак, разработка тестов — это тестирование или разработка?
1. Взгляд на происхождение разработки тестов с исторической точки зрения
В традиционном процессе разработки программного обеспечения разработка и тестирование часто разделены. Разработчики несут ответственность за написание кода и реализацию функциональной реализации, а тестировщики несут ответственность за тестирование кода, представленного разработчиками, для обеспечения его качества и стабильности. Хотя эта модель может гарантировать качество программных продуктов, разделение звена тестирования и звена разработки часто приводит к низкой эффективности и может привести к таким проблемам, как плохая коммуникация и несвоевременная обратная связь.
Чтобы решить эту проблему, некоторые компании начали пытаться совмещать процесс тестирования с процессом разработки. Тестировщики больше не просто тестируют код, представленный разработчиками, а участвуют во всем процессе разработки и сотрудничают с разработчиками, чтобы совместно обеспечивать качество программных продуктов. В ходе этого процесса тестировщикам приходится не только выполнять традиционную работу по тестированию, но и выполнять некоторые работы по разработке, такие как написание тестовых сценариев, создание тестовых сред и т. д. Это и есть начало разработки тестов.
2. Посмотрите на природу разработки тестов с точки зрения содержания работы.
Из приведенного выше описания мы видим, что содержание работы по разработке тестов включает в себя как тестирование, так и разработку. В частности, работа инженера по разработке тестов включает в себя:
1. Написание планов тестирования и тестовых примеров. Это основная работа процесса тестирования. Инженерам по разработке тестов необходимо писать подробные планы тестирования и тестовые сценарии на основе требований к продукту и пользовательских историй, чтобы гарантировать, что функции и производительность программных продуктов соответствуют ожиданиям.
2. Выполнение тестовых сценариев. После написания тестовых примеров инженеры-разработчики тестов должны выполнить эти сценарии использования для проведения фактического тестирования программного продукта. В этом процессе им необходимо использовать различные инструменты и технологии, такие как инструменты автоматического тестирования, инструменты тестирования производительности и т. д.
3. Отладка и исправление проблем. Если во время тестирования обнаруживаются проблемы и ошибки, инженерам по разработке тестов необходимо работать с разработчиками для отладки и устранения этих проблем. В ходе этого процесса им может потребоваться просмотреть журналы, проанализировать код, изменить код и т. д.
4. Написание и поддержка тестового кода. Чтобы повысить эффективность и качество тестирования, инженерам по разработке тестов необходимо писать и поддерживать тестовый код. Эти коды могут быть сценариями автоматизированного тестирования, сценариями тестирования производительности и т. д.
5. Создайте и поддерживайте тестовую среду. Чтобы обеспечить точность и надежность тестирования, инженерам по разработке тестов необходимо создать и поддерживать стабильную и надежную тестовую среду. Эта среда должна включать различное аппаратное, программное и сетевое оборудование.
3. Позиционирование разработки тестов с точки зрения требований к навыкам
Как видно из содержания работы, инженерам-разработчикам тестов необходимо обладать разнообразными навыками. Им необходимо понимать как теорию, так и практику тестирования программного обеспечения, а также овладеть определенными навыками разработки программного обеспечения. В частности, хороший инженер по разработке тестов должен обладать следующими навыками:
1. Теория и практика тестирования программного обеспечения. Это самый базовый навык. Им необходимо понимать различные методы и приемы тестирования программного обеспечения, такие как тестирование «черного ящика», тестирование «белого ящика», тестирование «серого ящика» и т. д. В то же время им также необходимо освоить использование различных инструментов тестирования, таких как Junit, Selenium и т. д.
2. Навыки разработки программного обеспечения. Хотя основной задачей инженеров по разработке тестов является тестирование, большая часть их работы связана с разработкой программного обеспечения. Следовательно, им необходимо обладать определенными навыками разработки программного обеспечения, такими как программирование на Java, программирование на Python и т. д.
3. Архитектура и дизайн системы. Чтобы проводить более эффективное тестирование, инженеры-разработчики тестов должны понимать архитектуру и дизайн системы. Им необходимо понимать взаимосвязи и взаимодействие между различными модулями и компонентами системы.
4. Эксплуатация и обслуживание баз данных. Во многих случаях хранение данных и управление программными продуктами основаны на базах данных. Поэтому инженеры-разработчики тестов должны понимать основные методы работы и обслуживания базы данных.
4. Взгляд на перспективы разработки тестов с точки зрения тенденций развития
С развитием разработки программного обеспечения и постоянным развитием технологий перспективы разработки тестов становятся все более широкими. Вот некоторые возможные тенденции:
1. Роль инженеров по разработке тестов станет более важной. С ростом популярности передовых моделей разработки, таких как гибкая разработка, непрерывная интеграция и непрерывная доставка, роль инженеров по разработке тестов станет более важной. Им придется более тесно сотрудничать с разработчиками, чтобы обеспечить качество и стабильность программных продуктов.
2. Автоматизированное тестирование станет более популярным. С развитием технологий автоматизированное тестирование станет массовым явлением. Инженерам по разработке тестов необходимо писать различные тестовые сценарии и инструменты для автоматического выполнения тестовых примеров и повышения эффективности и качества тестирования.
3. Инструменты тестирования станут более интеллектуальными. Инструменты тестирования в будущем станут более интеллектуальными и смогут автоматически выявлять и устранять проблемы. Это сделает работу инженеров-разработчиков тестов более эффективной и точной.
4. Тестирование и разработка будут более интегрированными. В будущем процесс разработки программного обеспечения будет более интегрированным. Инженерам по разработке тестов необходимо будет участвовать во всем процессе разработки и сотрудничать с разработчиками, чтобы совместно обеспечивать качество программных продуктов.
Подводя итог, можно сказать, что разработка тестов — это новая роль, сочетающая в себе тестирование и разработку. Это включает в себя как традиционную работу по тестированию, так и некоторую работу по разработке. С развитием разработки программного обеспечения и постоянным развитием технологий перспективы разработки тестов становятся все более широкими. В будущем роль инженеров по разработке тестов станет более важной, автоматизированное тестирование станет более популярным, инструменты тестирования станут более интеллектуальными, а тестирование и разработка будут более интегрированными.