文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何使用Cypress测试React原生应用

2024-12-02 03:17

关注

Cypress支持几乎所有的现代架构开发框架,比如Angular、React Native、Vu,以及MVC框架等等。

本文将讨论如何使用Cypress测试React Native应用程序。

什么是React Native应用程序?

React Native是一个基于JavaScript的开源框架,支持使用相同代码库在Android、iOS和Web应用等多个平台上构建不同类型的应用程序。

React Native允许人们访问本地视图、API和组件。因此,开发将更快,更高效。

构建React应用程序

Expo框架帮助构建 React Native应用程序。它支持基于相同代码库构建的Android、iOS和Web应用程序。Expo在Github中列出了很多有用的例子。

使用Expo,你可以构建一个简单的React原生应用:

1. 使用npm安装expo: npm install expo

2. 使用命令创建原生应用: npx create-react-native-app –template

3. 使用参考:

注意:端口可能会发生变化,运行命令后检查控制台的日志。

下面,我们使用一个空白的项目模板创建一个React应用程序,包含最基本的代码。 App.js 是主要的源代码,如下所示:

import { View, Text } from "react-native";
export default function App() {
  return (
    <View
      style={{
        flex: 1,
        justifyContent: "center",
        alignItems: "center",
      }}
    >
      <Text>Universal React with Expo</Text>
    </View>
  );
}

这样做是为了在设备上设置 React 应用程序。

如何用Cypress执行React应用程序测试

Cypress教程提供了关于设置Cypress的详细指南。

我们至少要做到以下几点:

1. 安装Cypress: npm install cypress

2. 打开Cypress 项目: npx cypress open

此时Cypress创建了目录的所有基本结构。

参考例子:

Expo my-react-app 访问地址是 http://localhost:19006/ ,所以我们需要访问这个地址来测试我们的应用程序。

我们之前创建的expo应用程序只有一组文本: “Universal React with Expo”. 我们使用一个简单的Cypress脚本来验证。

在你的项目目录中,创建 firsttest.js文件,并添加Cypress脚本来验证:

describe('My First Test', () => {
    it('Verify Text', () => {
        cy.visit('http://localhost:19006/');
        cy.get("div[id='root']").should('have.text', 'Universal React with Expo');
    });
})

在上面的代码中,我们正在访问到我们的本地网站,并验证文本是否存在。

使用React Native和Cypress验证API调用

大多数React Native应用都在内部调用API接口,所以我们也可以用Cypress来验证。

假设我们有一个React应用,它有一个API调用。

import React, { useEffect, useState } from 'react';
import { ActivityIndicator, FlatList, Text, View } from 'react-native';
export default function App() {
  const [isLoading, setLoading] = useState(true);
  const [data, setData] = useState([]);
  useEffect(() => {
    fetch('https://reqres.in/api/users?page=1')
      .then((response) => response.json())
      .then((json) => setData(json.data))
      .catch((error) => console.error(error))
      .finally(() => setLoading(false));
  }, []);

  return (
    <View style={{ flex: 1, padding: 24 }}>
      {isLoading ? <ActivityIndicator/> : (
        <FlatList
          accessibilityLabel="users"
          data={data}
          renderItem={({ item }) => (
            <Text testID="user" >{item.id}, {item.first_name}, {item.email}</Text>
          )}
        />
      )}
    </View>
  );
};

上面的代码调用API https://reqres.in/api/users?page=1 返回一组JSON值。我们应该能够断言body和status等的内容。

在React Native应用中验证API调用的Cypress脚本

describe('My First Test', () => {
    it('Verify API', () => {
        cy.intercept('*/users?*').as('users');
        cy.visit('http://localhost:19006/');
        cy.wait('@users').then(({response}) => {
            expect(response.statusCode).to.eq(200)
            expect(response.body.data.length).to.eq(6)
            expect(response.body.data[0].email).to.eq('george.bluth@reqres.in')
          })
   });
  })

在上面的代码中,我们使用Cypress Intercept特性,等待API加载。然后我们从API中获取响应,并在测试中验证它:

这样我们就可以在Cypress中测试React原生应用。此外,我们还可以设置Viewport并将其更改为不同的设备分辨率,以便测试移动Web应用程序。

原文Test React Native Apps With Cypress,作者:Ganesh Hegde

来源:51CTO内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯