如何使用Jest测试你的React组件

在本文中,我们将了解如何使用Jest(Facebook 维护的一个测试框架)来测试我们的React组件。我们将首先了解如何在纯 JavaScript 函数上使用 Jest,然后再了解它提供的一些开箱即用的功能,这些功能专门用于使测试 React 应用程序变得更容易。

值得注意的是,Jest 并不是专门针对 React:您可以使用它来测试任何 JavaScript 应用程序。然而,它提供的一些功能对于测试用户界面来说非常方便,这就是为什么它非常适合 React。

小丑杂耍 React 图标

应用测试示例

在我们测试任何东西之前,我们需要一个应用程序来测试!您可以在 GitHub 上找到它以及我们即将编写的所有测试。如果您想使用该应用程序来感受一下,您还可以在线找到现场演示。

该应用程序使用 ES2015 编写的,使用带有 Babel ES2015 和 React 预设的 webpack 进行编译。我不会详细介绍构建设置,但如果您想查看的话,一切都在 GitHub 存储库中。您可以在自述文件中找到有关如何在本地运行应用程序的完整说明。如果您想了解更多信息,该应用程序是使用webpack构建的,我推荐“ Webpack 初学者指南”进行学习。

应用程序的入口是app/index.js

  1. render(

  2. <Todos />,

  3. document.getElementById('app')

  4. );

Todos组件是应用程序的主要内容。它包含所有状态(该应用程序的硬编码数据,实际上可能来自 API 或类似数据),并有渲染两个子组件。

因为Todos组件包含所有状态,所以每当有任何变化时,它需要TodoAddTodo组件通知它。因此,它将函数向下传递到这些组件中,当某些数据发生变化时它们可以调用这些函数,并Todos可以相应地更新状态。

最后,现在您会注意到所有业务逻辑都包含在app/state-functions.js

  1. export function toggleDone(todos, id) {…}

  2. export function addTodo(todos, todo) {…}

  3. export function deleteTodo(todos, id) {…}

如果您熟悉 Redux,它们与 Redux 所谓的reducer非常相似。事实上,如果这个应用程序变得更大,会考虑迁移到 Redux 以获得更明确、结构化的数据方法。

选择 TDD 而不是 TDD?

关于测试驱动开发的优缺点已经有很多文章写过了,开发人员需要先编写测试,然后再编写修复测试的代码。这背后的想法是,通过先编写测试,您必须思考您正在编写的API,并且它可能会导致更好的设计。我认为这在很大程度上取决于个人偏好和测试的类型。我发现,对于React组件,我喜欢先编写组件,然后为最重要的功能添加测试。然而,如果您发现先为组件编写测试符合您的工作流程,那么您应该这样做。在这里没有硬性规定,做适合您和您的团队感觉最好的事情。

什么是Jest

Jest首次发布于2014年,尽管它最初引起了很多关注,但该项目一度停滞不前,并没有得到很积极的开发。然而,Facebook投入了大量精力来改进Jest,并发布了一些令人印象深刻的变化,值得重新考虑。与最初的开源发布相比,Jest仅保留了名称和标志。其他一切都已经改变和重写。如果您想了解更多信息,可以阅读Christoph Pojer的评论,他在其中讨论了该项目的当前状态。

如果您对使用其他框架设置Babel、React和JSX测试感到沮丧,那么我强烈建议您尝试Jest。如果您发现现有的测试安装速度很慢,我也强烈推荐Jest。它可以自动并行运行测试,其watch模式能够运行与更改文件相关的测试,这在您拥有大量测试套件时是非常宝贵的。它已经配置了JSDom,这意味着您可以编写浏览器测试但通过Node运行它们。它可以处理异步测试,并且具有内置的高级功能,如mocking、spy和stub。

安装和配置 Jest

首先,我们需要安装 Jest。因为我们也在使用 Babel,所以我们将安装另外几个模块,使 Jest 和 Babel 可以正常使用:

npm install --save-dev jest babel-jest @babel/core @babel/preset-env @babel/preset-react

您还需要一个babel.config.js包含 Babel 配置的文件,以使用您需要的任何预设和插件。如下所示:

  1. module.exports = {

  2. presets: [

  3. '@babel/preset-env',

  4. '@babel/preset-react',

  5. ],

  6. };

本文不会深入探讨 Babel 的设置。如果您想具体了解有关 Babel 的更多信息,看我以前的文章。

我们还不会安装任何 React 测试工具,因为我们不会从测试组件开始,而是从测试状态函数开始。

Jest 期望在一个文件夹中找到我们的测试__tests__,这已成为 JavaScript 社区中的一种流行惯例,我们将在这里坚持这一惯例。如果您不喜欢该__tests__设置,开箱即用的 Jest 还支持查找任何.test.js文件.spec.js

由于我们将测试我们的状态函数,因此请继续创建__tests__/state-functions.test.js。 下面是一个测试用例,进行测试检查Jest配置是否正常。

  1. describe('Addition', () => {

  2. it('knows that 2 and 2 make 4', () => {

  3. expect(2 + 2).toBe(4);

  4. });

  5. });

现在,进入您的package.json, 添加npm test命令:

  1. "scripts": {

  2. "test": "jest"

  3. }

如果您现在执行npm test命令,您应该会看到测试运行并通过!

  1. PASS __tests__/state-functions.test.js

  2. Addition

  3. ✓ knows that 2 and 2 make 4 (5ms)

  4. Test Suites: 1 passed, 1 total

  5. Tests: 1 passed, 1 total

  6. Snapshots: 0 passed, 0 total

  7. Time: 3.11s

如果您曾经使用过 Jasmine 或其他测试框架,Jest允许我们使用describe和it来嵌套测试。您使用多少嵌套取决于您。我喜欢嵌套我的测试,这样所有传递给describe和it的描述字符串几乎就像一个句子一样。

当涉及到实际断言时,您需要将要测试的内容包装在expect()调用中,然后在其上调用断言。在这种情况下,我们使用了toBe。您可以在Jest文档中找到所有可用断言的列表。toBe使用===来检查给定值是否与测试的值匹配。通过本教程,我们将遇到一些Jest的断言。

测试业务逻辑

我们将测试我们的第一个状态函数toggleDone。 toggleDone接收当前状态和我们想要切换的todo的ID。每个todo都有一个完成属性,而toggleDone应该将其从true切换为false,反之亦然。 注意:如果您正在跟随本文,确保已经克隆了代码库,并将app文件夹复制到包含您的__tests__文件夹的同一目录中。您还需要安装所有应用程序的依赖项(例如React)。在克隆存储库后运行npm install即可确保全部安装完成。

我将从app/state-functions.js导入函数并设置测试的结构开始。当Jest允许您使用describeit进行嵌套时,您也可以使用test,这通常更易于阅读。test只是Jest it函数的别名,但有时可以使测试更易于阅读,减少嵌套。例如,以下是我如何使用嵌套的describeit调用编写该测试的方法:

  1. import { toggleDone } from '../app/state-functions';

  2. describe('toggleDone', () => {

  3. describe('when given an incomplete todo', () => {

  4. it('marks the todo as completed', () => {

  5. });

  6. });

  7. });

这是test用法:

  1. import { toggleDone } from '../app/state-functions';

  2. test('toggleDone completes an incomplete todo', () => {

  3. });

测试仍然很容易读懂,但现在缩进少了一些。这主要取决于个人喜好;选择您更喜欢的风格即可。

现在我们可以编写断言了。首先,我们将创建我们的起始状态,然后将其传递到toggleDone中,以及我们要切换的todo的ID。toggleDone将返回我们的最终状态,然后我们可以对其进行断言:

  1. import { toggleDone } from "../app/state-functions";

  2. test("tooggleDone completes an incomplete todo", () => {

  3. const startState = [{ id: 1, done: false, text: "Buy Milk" }];

  4. const finState = toggleDone(startState, 1);

  5. expect(finState).toEqual([{ id: 1, done: true, text: "Buy Milk" }]);

  6. });

现在我使用toEqual进行断言。您应该使用toBe来测试原始值(例如字符串和数字),使用toEqual测试对象和数组。toEqual是专门用于处理数组和对象的,并且会递归检查给定对象内的每个字段或项目以确保其匹配。

有了这个,我们现在可以运行npm test并看到我们的状态函数测试通过:

  1. PASS __tests__/state-functions.test.js

  2. ✓ tooggleDone completes an incomplete todo (9ms)

  3. Test Suites: 1 passed, 1 total

  4. Tests: 1 passed, 1 total

  5. Snapshots: 0 passed, 0 total

  6. Time: 3.166s

配置热更新

在更改测试文件后,手动再次运行npm test有点繁琐。 Jest最好的功能之一是其监视模式,它会监视文件更改并相应地运行测试。它甚至可以根据更改的文件确定要运行的子集测试。它非常强大和可靠,您可以在监视模式下运行Jest,并在整天编写代码时保留它。

要在监视模式下运行它,您可以运行npm test -- watch。在第一个--之后传递给npm test的任何内容都将直接传递给基础命令。这意味着这两个命令是等效的:

  • npm test -- --watch
  • jest --watch

我建议您在另一个终端窗口中将Jest保留运行,以便在本教程的其余部分中使用。

在继续测试React组件之前,我们将在另一个状态函数上编写一个测试。在实际应用程序中,我会编写更多的测试,但是为了本教程的缘故,我将跳过其中一些。现在,让我们编写一个测试,以确保我们的deleteTodo函数正常工作。在查看下面我的编写方式之前,请尝试自己编写它并查看您的测试与我的测试有何不同。

请记住,您需要更新顶部的导入语句以导入deleteTodotoggleTodo

import { toggleDone, deleteTodo } from "../app/state-functions";

这是我编写测试用例:

  1. test('deleteTodo deletes the todo it is given', () => {

  2. const startState = [{ id: 1, done: false, text: 'Buy Milk' }];

  3. const finState = deleteTodo(startState, 1);

  4. expect(finState).toEqual([]);

  5. });

这个测试与第一个测试并没有太大的区别:我们设置起始状态,运行我们的函数,然后对最终状态进行断言。如果您已在监视模式下运行Jest,请注意它如何检测到您的新测试并运行它,以及它运行速度的快速性!这是一种在写测试时立即得到反馈的好方法。

上面的测试还演示了测试的过程,其中包括:

  • 设置
  • 执行要测试的功能
  • 对结果进行断言

通过以这种方式布局测试,您会发现更容易跟踪和处理它们。

现在我们已经满意测试我们的状态函数,让我们继续测试React组件。

测试 React 组件

值得注意的是,默认情况下,我实际上鼓励您不要在React组件上编写太多测试。您想要非常彻底测试的任何内容,例如业务逻辑,都应该从组件中提取出来并作为独立的函数存在,就像我们之前测试的状态函数一样。尽管如此,有时测试一些React交互(例如,确保用户单击按钮时调用特定函数并传递正确参数)是很有用的。我们将从测试我们的React组件是否呈现正确的数据开始,然后再看看如何测试交互。

为了编写测试,我们将安装Enzyme,这是由Airbnb编写的包装库,使测试React组件变得更加容易。

注意:自本文首次编写以来,React团队已经转向Enzyme,并推荐使用[React Testing Library(RTL)](https://testing-library.com/docs/react-testing-library/intro)。阅读该页面很值得一看。如果您正在维护已经使用Enzyme测试的代码库,则无需放弃所有内容并转移,但对于新项目,我建议考虑RTL

除了Enzyme之外,我们还需要安装适用于我们使用的React版本的适配器。对于React v16,使用enzyme-adapter-react-16,但对于React v17,目前没有官方适配器可用,因此我们必须使用非官方版本。请注意,该软件包旨在作为临时措施,直到正式支持发布,并将在那时被弃用。

npm install --save-dev enzyme @wojtekmaj/enzyme-adapter-react-17

我们需要对 Enzyme 进行少量设置。在项目的根目录中,创建setup-tests.js以下代码并将其放入其中:

  1. import { configure } from 'enzyme';

  2. import Adapter from '@wojtekmaj/enzyme-adapter-react-17';

  3. configure({ adapter: new Adapter() });

然后,我们需要告诉Jest在执行任何测试之前为我们运行此文件。我们可以通过配置setupFilesAfterEnv选项来实现这一点。您可以将Jest配置放在自己的文件中,但我喜欢使用package.json并将东西放在jest对象中,Jest也会自动检测到它:

  1. "jest": {

  2. "setupFilesAfterEnv": [

  3. "./setup-tests.js"

  4. ]

  5. }

现在我们准备编写一些测试了!让我们测试该Todo组件是否在段落内呈现其待办事项的文本。首先我们将创建__tests__/todo.test.js并导入我们的组件:

  1. import Todo from '../app/todo';

  2. import React from 'react';

  3. import { mount } from 'enzyme';

  4. test('Todo component renders the text of the todo', () => {

  5. });

Enzyme导入了mountmount函数用于呈现我们的组件,然后允许我们检查输出并对其进行断言。即使我们在Node中运行测试,我们仍然可以编写需要DOM的测试。这是因为Jest配置了jsdom,一个在Node中实现DOM的库。这很好,因为我们可以编写基于DOM的测试,而无需每次启动浏览器进行测试。

可以使用mount来创建我们的Todo

  1. const todo = { id: 1, done: false, name: 'Buy Milk' };

  2. const wrapper = mount(

  3. <Todo todo={todo} />

  4. );

然后,我们可以调用wrapper.find,给它一个CSS选择器,以查找我们希望包含Todo文本的段落。这个API可能会让您想起jQuery,这是有意设计的。这是一个在渲染的输出中搜索匹配元素的非常直观的API。

const p = wrapper.find('.toggle-todo');

最后,我们可以断言其中的文本是Buy Milk

expect(p.text()).toBe('Buy Milk');

完整的测试用例是这样的:

  1. import Todo from '../app/todo';

  2. import React from 'react';

  3. import { mount } from 'enzyme';

  4. test('TodoComponent renders the text inside it', () => {

  5. const todo = { id: 1, done: false, name: 'Buy Milk' };

  6. const wrapper = mount(

  7. <Todo todo={todo} />

  8. );

  9. const p = wrapper.find('.toggle-todo');

  10. expect(p.text()).toBe('Buy Milk');

  11. });

现在我们有了一个测试,可以检查我们是否成功地渲染了todos。 接下来,让我们看一下如何使用Jest的spy功能来断言具有特定参数的函数被调用。在我们的情况下很有用,因为我们有一个Todo组件,它被赋予了两个函数作为属性,当用户单击按钮或执行交互时应该调用这些函数。

在这个测试中,我们将断言当Todo被单击时,组件将调用它所赋予的doneChange属性:

  1. test('Todo calls doneChange when todo is clicked', () => {

  2. });

我们希望有一个可以用来跟踪其调用及其调用参数的函数。然后,我们可以检查当用户单击Todo时,doneChange函数是否被调用,并且被调用时使用了正确的参数。幸运的是,Jest在功能上提供了这个功能来使用spy(间谍)spy是一种函数,其实现方式并不重要,您只需要关心它何时以及如何被调用。可以将其想象为您在侦察该函数。要创建一个spy,我们调用jest.fn()

const doneChange = jest.fn(); 

这提供了一个函数,我们可以对其进行监视并确保其被正确调用。让我们从使用正确的props来呈现我们的Todo开始:

  1. const todo = { id: 1, done: false, name: 'Buy Milk' };

  2. const doneChange = jest.fn();

  3. const wrapper = mount(

  4. <Todo todo={todo} doneChange={doneChange} />

  5. );

接下来,我们可以再次查找我们的段落,就像在前面的测试中一样:

const p = wrapper.find(".toggle-todo"); 

然后我们可以调用simulate它来模拟用户事件,并click作为参数传递:

p.simulate('click');

现在我们只需要断言我们的spy函数是否被正确调用。在这种情况下,我们期望它被调用时使用了ID为1的todo。我们可以使用expect(doneChange).toBeCalledWith(1)来断言这一点,然后我们的测试就完成了!

  1. test('TodoComponent calls doneChange when todo is clicked', () => {

  2. const todo = { id: 1, done: false, name: 'Buy Milk' };

  3. const doneChange = jest.fn();

  4. const wrapper = mount(

  5. <Todo todo={todo} doneChange={doneChange} />

  6. );

  7. const p = wrapper.find('.toggle-todo');

  8. p.simulate('click');

  9. expect(doneChange).toBeCalledWith(1);

  10. });

结论

Facebook很久以前就发布了Jest,但最近已经被广泛采用和改进。它已经快速成为JavaScript开发人员的首选,而且它只会变得更好。如果你以前尝试过Jest并且不喜欢它,我无法足够地鼓励你再次尝试它,因为现在它基本上是一个完全不同的框架。它快速,重复运行规格非常出色,提供了出色的错误消息,并且有一个出色的表达式API,用于编写良好的测试。

 感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/923579.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

硬菜!高精度!BO-Transformer贝叶斯优化编码器多特征分类预测/故障诊断

硬菜&#xff01;高精度&#xff01;BO-Transformer贝叶斯优化编码器多特征分类预测/故障诊断 目录 硬菜&#xff01;高精度&#xff01;BO-Transformer贝叶斯优化编码器多特征分类预测/故障诊断效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab实现BO-Transform…

仿真学习 | Abaqus版本差异详解:哪版更适合你的仿真作业?

​ 引言 在上一篇文章《仿真学习 | Fluent版本迭代一览及选择指南》中&#xff0c;我们深入探讨了Fluent的不同版本以及如何根据自身需求选择最合适的版本。今天&#xff0c;我们将把视线聚焦于Abaqus——另一款在工程仿真领域中备受推崇的软件。 在有限元分析领域&#xff0c;…

NLP论文速读(剑桥大学出品)|分解和利用专家模型中的偏好进行改进视觉模型的可信度

论文速读|Decompose and Leverage Preferences from Expert Models for Improving Trustworthiness of MLLMs 论文信息&#xff1a; 简介&#xff1a; 本文探讨的背景是多模态大型语言模型&#xff08;MLLMs&#xff09;&#xff0c;这类模型通过结合视觉特征和文本空间来增强语…

IntelliJ IDEA 中,自动导包功能

在 IntelliJ IDEA 中&#xff0c;自动导包功能可以极大地提高开发效率&#xff0c;减少手动导入包所带来的繁琐和错误。以下是如何在 IntelliJ IDEA 中设置和使用自动导包功能的详细步骤&#xff1a; 一、设置自动导包 打开 IntelliJ IDEA&#xff1a; 启动 IntelliJ IDEA 并打…

红外小目标检测

目录 背景概述算法原理演示效果核心逻辑 使用方式基础镜像配置环境直接运行 参考文献 文章声明&#xff0c;非广告&#xff0c;仅个人体验。 背景 红外图像在许多领域中都有所应用。例如军事领域中&#xff0c;经常需要通过红外成像设备对远距离的目标进行侦察和监视&#xff…

hive的存储格式

1&#xff09; 四种存储格式 hive的存储格式分为两大类&#xff1a;一类纯文本文件&#xff0c;一类是二进制文件存储。 Hive支持的存储数据的格式主要有&#xff1a;TEXTFILE、SEQUENCEFILE、ORC、PARQUET 第一类&#xff1a;纯文本文件存储 textfile: 纯文本文件存储格式…

ReentrantLock(可重入锁) Semaphore(信号量) CountDownLatch

目录 ReentrantLock(可重入锁) &Semaphore(信号量)&CountDownLatchReentrantLock(可重入锁)既然有了synchronized&#xff0c;为啥还要有ReentrantLock?Semaphore(信号量)如何确保线程安全呢&#xff1f;CountDownLatch ReentrantLock(可重入锁) &Semaphore(信号量…

51单片机从入门到精通:理论与实践指南入门篇(二)

续51单片机从入门到精通&#xff1a;理论与实践指南&#xff08;一&#xff09;https://blog.csdn.net/speaking_me/article/details/144067372 第一篇总体给大家在&#xff08;全局&#xff09;总体上讲解了一下51单片机&#xff0c;那么接下来几天结束详细讲解&#xff0c;从…

STM32C011开发(2)----nBOOT_SEL设置

STM32C011开发----2.nBOOT_SEL设置 概述硬件准备视频教学样品申请源码下载参考程序自举模式BOOT0设置配置 nBOOT_SEL生成STM32CUBEMX串口配置LED配置堆栈设置串口重定向主循环演示 概述 STM32CubeProgrammer (STM32CubeProg) 是一款用于编程STM32产品的全功能多操作系统软件工…

基于 AI 的软件工程: 超级程序员

徐昊 《AI时代的软件工程》-极客时间课程学习总结 帮助你更好地利用 LLM 提高效率,还可以站在一个更全面的立场上,讨论如何将 LLM 引入团队或是组织。 核心观点: AI 辅助业务建模:通过将模型转化为 Mermaid 格式,将我们的模型表达为大语言模型能够理解的形式。通过添加注…

【消息序列】详解(7):剖析回环模式--设备测试的核心利器

目录 一、概述 1.1. 本地回环模式 1.2. 远程环回模式 二、本地回环模式&#xff08;Local Loopback mode&#xff09; 2.1. 步骤 1&#xff1a;主机进入本地环回模式 2.2. 本地回环测试 2.2.1. 步骤 2a&#xff1a;主机发送HCI数据包并接收环回数据 2.2.2. 步骤 2b&…

如何使用GCC手动编译stm32程序

如何不使用任何IDE&#xff08;集成开发环境&#xff09;编译stm32程序? 集成开发环境将编辑器、编译器、链接器、调试器等开发工具集成在一个统一的软件中&#xff0c;使得开发人员可以更加简单、高效地完成软件开发过程。如果我们不使用KEIL,IAR等集成开发环境&#xff0c;…

计算机网络 第4章 网络层

计算机网络 &#xff08;第八版&#xff09;谢希仁 第 4 章 网络层4.2.2 IP地址**无分类编址CIDR**IP地址的特点 4.2.3 IP地址与MAC地址4.2.4 ARP 地址解析协议4.2.5 IP数据报的格式题目2&#xff1a;IP数据报分片与重组题目&#xff1a;计算IP数据报的首部校验和(不正确未改) …

【Git】常用命令汇总

目录 一.安装及配置 1.在 Windows 上安装 2.用户信息 3.差异分析工具 二.基础 1.创建仓库 2.提交与修改 三.分支管理 1.创建分支 2.合并分支 四.远程操作 1.管理 Git 仓库中的远程仓库 2.数据的获取与推送 五.标签 1.创建轻量标签和附注标签 2.查看标签和标签信…

jvm核心组件介绍

1. 类加载器&#xff08;ClassLoader&#xff09;&#xff1a; • 想象它是一个快递员&#xff0c;负责把Java类&#xff08;.class文件&#xff09;这个“包裹”从磁盘这个“发货地”送到JVM内部这个“目的地”。类加载器确保每个类只被加载一次&#xff0c;并维护一个类的层级…

【Docker】常用命令汇总

Docker 是1个开源的应用容器引擎&#xff0c;基于Go 语言并遵从 Apache2.0 协议开源。 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中&#xff0c;然后发布到任何流行的 Linux 机器上&#xff0c;也可以实现虚拟化。 容器是完全使用沙箱机制&#xff0c;相…

ChatGPT如何辅助academic writing?

今天想和大家分享一篇来自《Nature》杂志的文章《Three ways ChatGPT helps me in my academic writing》&#xff0c;如果您的日常涉及到学术论文的写作&#xff08;writing&#xff09;、编辑&#xff08;editing&#xff09;或者审稿&#xff08; peer review&#xff09;&a…

对比C++,Rust在内存安全上做的努力

简介 近年来&#xff0c;越来越多的组织表示&#xff0c;如果新项目在技术选型时需要使用系统级开发语言&#xff0c;那么不要选择使用C/C这种内存不安全的系统语言&#xff0c;推荐使用内存安全的Rust作为替代。 谷歌也声称&#xff0c;Android 的安全漏洞&#xff0c;从 20…

【网络安全设备系列】12、态势感知

0x00 定义&#xff1a; 态势感知&#xff08;Situation Awareness&#xff0c;SA&#xff09;能够检测出超过20大类的云上安全风险&#xff0c;包括DDoS攻击、暴力破解、Web攻击、后门木马、僵尸主机、异常行为、漏洞攻击、命令与控制等。利用大数据分析技术&#xff0c;态势感…

UE5 slate BlankProgram独立程序系列

源码版Engine\Source\Programs\中copy BlankProgram文件夹&#xff0c;重命名为ASlateLearning&#xff0c;修改所有文件命名及内部名称。 ASlateLearning.Target.cs // Copyright Epic Games, Inc. All Rights Reserved.using UnrealBuildTool; using System.Collections.Ge…