Type something to search...
利用 Gen AI(OpenAI API)构建智能测试自动化

利用 Gen AI(OpenAI API)构建智能测试自动化

我们都知道 UI 测试非常脆弱。它们可能因各种原因而失败,其中一个最大的问题是 UI 定位器的变化。很难想象我们如何能让它们足够智能,以理解定位器何时发生变化,并在测试中出现定位器问题之前防止测试运行。

你没听错!现在是 2024 年,自动化测试工具已经取得了长足的进步。在与这些工具打交道近 18 年后,从 Mercury Winrunner 到 Playwright,我们现在可以利用生成性 AI 的强大功能做一些真正令人惊叹的事情。这就像魔法,但这是真正的科学!

没错,我们现在可以找到一种方法,让我们的测试自动化代码 更智能,而不需要自己编写各种模糊的数学算法,这一切都由 LLM 的神来处理。

在这篇文章中,我们将讨论如何以更有效和高效的方式使我们的测试变得智能,但同样,要实现这一点,您需要具备以下前提条件:

  1. Open AI API 带信用额度(您需要即时购买)

2. C# .NET 代码知识,因为我将要涵盖的代码来自 .NET 和 Selenium

3. 对测试自动化的基本理解

再次强调,以上所有内容以及以下讨论都是我 Udemy 课程 的一部分,该课程涵盖了更详细的内容和逐步编写代码的方法。

让我们理解问题陈述

我们有一个页面,希望使用 Selenium C# 代码进行自动化。我们使用页面对象模型(POM)模式编写了非常好的代码,一切看起来都很棒,并且完美运行,如下所示。

我们的开发冠军发现了一个需要调整的 UI 元素。他根据同事的代码审查意见进行了更改,但不幸的是,他删除了我们在自动化测试中使用的定位器。这意味着我们的 POM 代码将不再工作,因为定位器不再存在,这最终导致测试 失败

最重要的是,由于单个定位器的更改,所有测试场景都将因相同的失败而失败。测试并不知道定位器已更改,也没有任何方法知道这一点,因此它总是失败。

如何解决这个问题?

我相信像我一样,很多人在使用 UI 测试工具时,每天都在经历这个问题,无论是 CypressSelenium 还是 Playwright。这个问题总是存在,无论使用什么工具。

现在让我们来理解如何解决上述问题。

我们都知道 生成式 AI大型语言模型(LLMs)已经远远超出了文本/图像/视频生成的范畴。它们理解给定的上下文,并生成我们所寻找的有意义的信息集。

因此,针对上述问题,我们可以利用生成式 AI 的力量,通过 OpenAI 的 API,将我们的提示请求传递给像 GPT 4oGPT 4 turbo 的 LLM,以理解问题陈述并给出有意义的解决方案。

那么,我们需要向 OpenAI 的 API 传递什么提示请求,以便在我们的测试自动化中执行操作呢?

好吧,这张图将给你答案。

我们可以将应用程序的“实际测试页面”和 Selenium 测试的“页面对象模型”代码作为提示发送给 OpenAI 的 API(附带一些额外的响应解析细节)。这将作为 OpenAI API 的验证过程,以查看定位器是否与给定页面匹配。

根据该操作,我们可以决定测试是否执行。定位器发生了变化,因此继续运行测试是没有意义的。

执行上述操作的代码大致如下:

public static async Task<string> VerifyPageLocatorFromAiAsync(string pomFileContent, string htmlPageSource)
{
    ChatClient client = new(model: "gpt-4o-mini", apiKey);
    
    var chatMessage = $"Verify if locators from this Selenium POM class: {pomFileContent} match this page source: {htmlPageSource}\", only return True or False result";

    ChatCompletion completion = await client.CompleteChatAsync(chatMessage);

    return completion.Content.FirstOrDefault().Text;
}

上述代码只是课程中涉及的大量代码的一部分,但你可以看到如何简单地执行将页面与 Selenium 的页面对象模型代码进行分析的操作。

GenAI在软件测试课程中

以上讨论只是我在Udemy新课程“在软件自动化测试中使用生成性AI”中讨论主题的一部分

以下是课程内容

该课程目前在Udemy上以优惠价格提供,作为首发优惠,请在购买课程时使用优惠码EA_NOV_24 ⚡️

如果优惠码已过期,请随时在此帖子下留言,我会将最新的可用优惠码发送给您。

Related Posts

结合chatgpt-o3-mini与perplexity Deep Research的3步提示:提升论文写作质量的终极指南

结合chatgpt-o3-mini与perplexity Deep Research的3步提示:提升论文写作质量的终极指南

AI 研究报告和论文写作 合并两个系统指令以获得两个模型的最佳效果 Perplexity AI 的 Deep Research 工具提供专家级的研究报告,而 OpenAI 的 ChatGPT-o3-mini-high 擅长推理。我发现你可以将它们结合起来生成令人难以置信的论文,这些论文比任何一个模型单独撰写的都要好。你只需要将这个一次性提示复制到 **

阅读更多
让 Excel 过时的 10 种 Ai 工具:实现数据分析自动化,节省手工作业时间

让 Excel 过时的 10 种 Ai 工具:实现数据分析自动化,节省手工作业时间

Non members click here作为一名软件开发人员,多年来的一个发现总是让我感到惊讶,那就是人们还在 Excel

阅读更多
使用 ChatGPT 搜索网络功能的 10 种创意方法

使用 ChatGPT 搜索网络功能的 10 种创意方法

例如,提示和输出 你知道可以使用 ChatGPT 的“搜索网络”功能来完成许多任务,而不仅仅是基本的网络搜索吗? 对于那些不知道的人,ChatGPT 新的“搜索网络”功能提供实时信息。 截至撰写此帖时,该功能仅对使用 ChatGPT 4o 和 4o-mini 的付费会员开放。 ![](https://images.weserv.nl/?url=https://cdn-im

阅读更多
掌握Ai代理:解密Google革命性白皮书的10个关键问题解答

掌握Ai代理:解密Google革命性白皮书的10个关键问题解答

10 个常见问题解答 本文是我推出的一个名为“10 个常见问题解答”的新系列的一部分。在本系列中,我旨在通过回答关于该主题的十个最常见问题来分解复杂的概念。我的目标是使用简单的语言和相关的类比,使这些想法易于理解。 图片来自 [Solen Feyissa](https://unsplash.com/@solenfeyissa?utm_source=medium&utm_medi

阅读更多
在人工智能和技术领域保持领先地位的 10 项必学技能 📚

在人工智能和技术领域保持领先地位的 10 项必学技能 📚

在人工智能和科技这样一个动态的行业中,保持领先意味着不断提升你的技能。无论你是希望深入了解人工智能模型性能、掌握数据分析,还是希望通过人工智能转变传统领域如法律,这些课程都是你成功的捷径。以下是一个精心策划的高价值课程列表,可以助力你的职业发展,并让你始终处于创新的前沿。 1. 生成性人工智能简介课程: [生成性人工智能简介](https://genai.works

阅读更多
揭开真相!深度探悉DeepSeek AI的十大误区,您被误导了吗?

揭开真相!深度探悉DeepSeek AI的十大误区,您被误导了吗?

在AI军备竞赛中分辨事实与虚构 DeepSeek AI真的是它所宣传的游戏规则改变者,还是仅仅聪明的营销和战略炒作?👀 虽然一些人将其视为AI效率的革命性飞跃,但另一些人则认为它的成功建立在借用(甚至窃取的)创新和可疑的做法之上。传言称,DeepSeek的首席执行官在疫情期间像囤积卫生纸一样囤积Nvidia芯片——这只是冰山一角。 从其声称的550万美元培训预算到使用Open

阅读更多
Type something to search...