首页
学习
活动
专区
圈层
工具
发布

【DB笔试面试745】在Oracle中,RAC环境下的Redo文件可以放在节点本地吗?

♣ 题目部分 在Oracle中,RAC环境下的Redo文件可以放在节点本地吗? ♣ 答案部分 不能。...同单实例的系统一样,在RAC环境中,每个节点实例都需要至少两组Redo日志文件,且每个节点实例有自己独立的Redo日志线程(由初始化参数THREAD定义),例如: SQL> SELECT B.THREAD...4 STALE +DATA/lhrdb/onlinelog/group_4.266.660615543 52428800 YES INACTIVE RAC环境中的...Redo日志文件必须部署到共享存储中,而且需要保证可被集群内的所有节点实例访问到。...当某个节点实例进行实例恢复或介质恢复的时候,该节点上的实例将可以应用集群下所有节点实例上的Redo日志文件,从而保证恢复可以在任意可用节点进行。

4.6K30

Mock和Spy的真面目:你的测试是在真的隔离依赖还是在自欺欺人?

这个对话促使我深度思考mock和spy两个工具。很多开发者把它们当成了测试中的"魔法道具",会用但不知道在做什么。更恐怖的是,很多人写出来的测试根本没在测试真正重要的东西。...这就是脆弱的测试。 Mock的第三个坑:模拟返回值时不够真实 Mock最强大的地方是可以模拟各种场景。但很多人只模拟了成功的情况: // 模拟邮件服务返回成功 jest.mock('....两个库的哲学有点不同。 Jest的风格:自动化Mock Jest会在模块加载时自动处理mock。你在测试文件顶部写 jest.mock('..../emailService'),之后所有这个模块的导入都会被替换。 jest.mock('....Mock本身,不是在测你的代码 }); 第六部分:实战建议—何时用Mock,何时用Spy 让我总结一个决策树,帮你在真实项目中选择: 你需要验证一个函数吗?

12510
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    万字详文:彻底搞懂 Jest 单元测试框架

    ,为了测试在同一个文件夹中创建一个测试文件,命名为 test.spec.js,这特殊的后缀是 Jest 的约定,用于查找所有的测试文件。...我们还将导入被测函数,以便执行测试中的代码。...模拟 在复杂的测试场景,我们一定绕不开一个 Jest 术语:模拟(mock) 在 Jest 文档中,我们可以找到 Jest 对模拟有以下描述:”模拟函数通过抹去函数的实际实现、捕获对函数的调用,以及在这些调用中传递的参数.../packages/jest-cli/bin/jest.js /path/test.spec.js 就会执行 jest.js 文件,然后进入到 build/cli 文件中的 run 方法,run 方法会对命令中各种的参数做解析...vm 模块来真正的执行 js,vm 模块接受安全的源代码,并用 V8 虚拟机配合传入的上下文来立即执行代码或者延时执行代码,这里可以接受不同的作用域来执行同一份代码来运算出不同的结果,非常合适测试框架的使用

    9.3K20

    JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互

    此类模拟文件在 _ mocks _ 目录中定义,在该目录中,文件名被视为模拟模块的名称。...(例如 fs 或 path ),则需要在模拟文件中明确调用 jest.mock('moduleName') Jest 允许我们对函数进行监视:接下来测试是否调用了我们所创建的 get 函数。...你还可以通过在 package.json 文件中添加以下代码段来使其成为默认行为: "jest": { "clearMocks": true } 模拟获取 API 另一个常见情况是使用 Fetch...,将其导入 setupTests.js 文件中。...从测试中返回 promise 是能够确保 Jest 等待其解决的一种方法。 总结 在本文中,我们介绍了模拟模块,并将其用于伪造 API 调用。由于没有发出实际的请求要求,我们的测试可以更可靠、更快。

    5K10

    Jest中Mock网络请求

    Jest中Mock网络请求 最近需要将一个比较老的库修改为TS并进行单元测试,修改为TS还能会一点,单元测试纯粹是现学现卖了,初学Jest框架,觉得在单元测试中比较麻烦的就是测试网络请求,所以记录一下Mock...,在Jest启动时会进行编译,在这里将这个库mock掉后,所有在之后引入这个库的文件都是会获得mock后的对象,也就是说我们可以认为这个库已经重写了,重写之后的方法都是JEST的Mock Functions...,所幸Jest提供了一种可以直接实现被Mock的函数库的方式,当然实际上Jest还提供了mockImplementation的方式,这个是在demo3中使用的方式,在这里我们重写了被mock的函数库,在实现的时候也可以使用...单元测试启动前与全部测试完毕后进行的操作,我们将服务器启动与关闭的操作都放在这里,请注意,在这两个文件运行的文件是单独的一个独立context,与任何进行的单元测试的context都是无关的,包括setupFiles...,要么就是通过网络进行数据传输,即在服务器运行的过程中通过指定path然后该path的网络请求会携带数据,在服务器的闭包中会把这个数据请求指定,当然在这里两种方式都支持,我觉得还是在每个单元测试文件中指定一个自己的数据比较合适

    3.8K30

    Jest中Mock网络请求

    操作,在Jest启动时会进行编译,在这里将这个库mock掉后,所有在之后引入这个库的文件都是会获得mock后的对象,也就是说我们可以认为这个库已经重写了,重写之后的方法都是JEST的Mock Functions...,所幸Jest提供了一种可以直接实现被Mock的函数库的方式,当然实际上Jest还提供了mockImplementation的方式,这个是在demo3中使用的方式,在这里我们重写了被mock的函数库,在实现的时候也可以使用...在这里就使用到了jest-axios-mock-server库,首先我们需要指定三个文件,分别对应每个单元测试文件启动前执行,Jest测试启动前执行,与Jest测试完成后执行的三个生命周期进行的操作,分别是...单元测试启动前与全部测试完毕后进行的操作,我们将服务器启动与关闭的操作都放在这里,请注意,在这两个文件运行的文件是单独的一个独立context,与任何进行的单元测试的context都是无关的,包括setupFiles...,要么就是通过网络进行数据传输,即在服务器运行的过程中通过指定path然后该path的网络请求会携带数据,在服务器的闭包中会把这个数据请求指定,当然在这里两种方式都支持,我觉得还是在每个单元测试文件中指定一个自己的数据比较合适

    3.1K30

    一杯茶的时间,上手 Jest 测试框架

    \ afterAll (这里由于篇幅,这一类进阶特性将放在后续的教程中)为其下所有 test 进行统一描述和处理。...4.Jest最锋利的功能 Mock Functions 关于 Jest 测试框架中的Mock功能,我们主要关注两点: mock function: 对函数进行mock. mock return value...从以上两点可以衍生出 Jest 对于代码单元测试中两项常用的锋利功能: 对功能中业务逻辑简化后的重新实现,方便有指向性的进行测试(比如忽略实际场景中的跨服务调用功能等,仅需将原有功能中对应的调用逻辑改为定义的测试数据即可...这里我们通过 .mockReturnValu 可以将 function mock 的操作略过,直接会返回 .mockReturnValue 中填充的返回值。通过执行 npm test 验证。...通过 jest.mock ,我们 mock 了甜点评论区,这项操作可以使我们对dessertCommentModule中的所有功能进行我们的测试定制。

    2.4K20

    怎么给测试代码做抽象才是有意义的?

    前言 哈喽,大家好,我是海怪。 不知道大家在写前端单测的时候,是否有出现测试代码和测试数据重复冗余的情况?然后不得不写一些函数和类来封装他们的。...假如现在有 20 多个这样的测试用例放在一个文件里,你是不是看着很难受?你可能会说:哪有那么夸张?别笑,像这样的我见太多了。...所以,这里更推荐是可以在前面加一个 setup 函数用于生成对应的 user 内容,然后再在具体的用例中 用非常明显的方式 去添加这个用例的 “独特之处”(比如名字变了之类的) import { getUserById...总的来说,我是认可作者的观点的,因为我们写单测时难免会遇到要构造一堆 Mock 对象、实例的情况,而且对不同的测试用例 Mock 内容可能仅有细微差别。...所以最好的方式还是在当前测试文件中,写一个 setup 函数来生成基础的 Mock 对象,然后再在对应用例中做细微差别的调整即可,并尽量把差异化展现出来。

    99020

    测试中如何处理 Http 请求?

    这会好点,但这也会遇到第 1 点类似的问题 把所有东西都放在函数中,然后拿来做单测(这样还行),这样就避免在集成测试中再测一遍(不太好,译注:不太好是因为集成测试应该要对整个功能进行测试,这样分开测就不完整了...这里举个例子: // 把它放在 Jest 的 setup 文件中,就会在所有测试文件前被引入了 import * as users from '....Colocation 和 error/edge case testing 唯一值得担心的是:你可能会把所有 Server Handler 放在同一个地方,而依赖它们的测试文件又会被放在不同地方,这可能会导致文件放置不集中...首先,我想说的是,只有那些对你测试很重要,很独特的东西才应该尽可能靠近测试文件。 你不需要在所有测试文件中都要重复 setup 一次,只需要 setup 独特的东西就可以了。...总的来说,我还是挺喜欢拦截 Http 请求这种 Mock 方法的。msw 不仅可以在测试中拦截请求,实现集成、E2E 测试,还可以在前端开发时来 Mock 数据,确实是一个有趣的实践。

    1.9K10

    2024 年必会的 10 个 Node.js 新特性,你还不知道就太落伍了!

    可以使用 --reporter 选项指定报告器。 node --test --test-reporter=tap 你应该放弃 Jest 吗?...安装 Jest 即使只是开发依赖,也会引入 277 个不同许可证的间接依赖,包括 MIT、Apache-2.0、CC-BY-4.0 和一个未知许可证。你知道吗?..., 1); }); }); 在测试文件中,我们从 node:test 导入 mock 方法,用它创建 fs.readFile 的模拟实现。...通过 Node.js 的原生模拟功能,我们可以有效地将 loadEnv 函数与文件系统隔离,进行独立测试。Node.js 20 的模拟功能还支持模拟定时器。 什么是 Mock?...在软件测试中,Mock 是用人工功能替代特定模块的实际功能。其主要目的是将测试单元与外部依赖隔离,确保测试只验证单元功能,而非依赖。

    2K10

    那些年错过的React组件单元测试(上)

    写在前面 关于前端单元测试,其实两年前我就已经关注了,但那时候只是简单的知道断言,想着也不是太难的东西,项目中也没有用到,然后就想当然的认为自己就会了。 两年后的今天,部门要对以往的项目补加单元测试。...然后我翻阅了大量的文档,发现基于dva的单元测试文档比较少,因此在有了一番实践之后,我梳理了几篇文章,希望对于想使用 Jest 进行 React + Dva + Antd 单元测试的你能有所帮助。...: automock: 告诉 Jest 所有的模块都自动从 mock 导入. clearMocks: 在每个测试前自动清理 mock 的调用和实例 instance collectCoverage: 是否收集测试时的覆盖率信息...jest中与mock相关的api主要有三个,分别是jest.fn()、jest.mock()、jest.spyOn()。使用它们创建mock函数能够帮助我们更好的测试项目中一些逻辑较复杂的代码。...我们在测试中也主要是用到了mock函数提供的以下三种特性: 捕获函数调用情况 设置函数返回值 改变函数的内部实现 下面,我将分别介绍这三种方法以及他们在实际测试中的应用。

    6.5K20

    Vue Router 之单元测试

    可以在 测试中共用一个 localVue,故将其声明在第一个 describe 块之外。而由于要为不同的路由做不同的测试,所以把 router 定义在了 it 块里。...如果你在用 Jest,其强大的 mocking 系统为此提供了一个优雅的解决方法。可以简单的 mock 掉子组件,在本例中也就是 。...,我们借助 jest.mock,mock 掉了整个模块,并用 afterEach 钩子将其复原(译注:不要混淆这里 Jest 的 afterEach 和导入的 router 的 beforeEach)。...通过将 beforeEach 导出为一个已解耦的、普通的 Javascript 函数,从而让其在测试过程中不成问题。...总结 本文覆盖了: 测试由 Vue Router 条件渲染的组件 用 jest.mock 和 localVue 去 mock Vue 组件 从 router 中解耦全局导航 guard 并对其独立测试

    2.4K10

    前端单元测试之Jest

    一个sum2.js 文件的话,需要在sum2.js 同级目录下新建文件夹__mock__,然后在此文件下新建文件同名 sum2.js,然后mock返回100。...export default function sum2(a, b) { return 100; } 然后,新建一个mock_file.test.js测试文件。 jest.mock('.....当有异步方式运行的代码的时候,Jest需要知道当前它测试的代码是否已经完成,然后它才可以转移动另一个测试中,也就是说,测试的用例一定要在测试对象结束之后才能够运行。...Snapshot 快照测试第一次运行的时候会将被测试ui组件在不同情况下的渲染结果保存一份快照文件,后面每次再运行快照测试时,都会和第一次的比较,除非执行“yarn test – -u”命令删除快照文件...] = ` 我是react组件 `; 如果被测试代码有正常更新,可以使用“jest --updateSnapshot ”命令重新更新缓存文件。

    3.7K20

    浅谈前端测试

    方法使得测试达到我们预期的目的,在这个简单的场景里面我们只需要模拟返回值就好   2.expect(console.log) 这里会报错,因为 jest 断言的内容只能是 mock function...或 spy,这里 console 是全局对象 global 上的方法,我们没有 require 将其引入,所以 jest.mock 显然处理上有些吃力,这时候 spy 就派上用场了,beforeAll...()  })   每次执行 test 前先清除 mock,避免多个测试用例之间复杂化 mock 导致错误   小结:单元测试中的 mock 是个测试思路,我们无需关心外部文件和依赖是什么,只要能模拟出正确的情况程序是否按规则执行...,试着这样写 jest.mock(${process.cwd()}/package.json, () => mockFile) 会报错,所以尽量使用可以 mock 的方案,保证单元测试可以顺利进行,修改如下...  强关联测试,证明 map 方法的确执行了,并且参数正确,先 spy spyOn(Array.prototype, 'map') 然后断言   聊了一圈从覆盖率聊到了测试健壮性的问题,可以思考下写过的测试是否真的满足注释或修改任何一行代码都能引起测试的

    2.2K10

    Jest 单元测试快速上手指南

    , 容易上手且功能十分强大的测试框架 安装 yarn add -D jest 使用 创建 test 目录, 添加 plus.spec.js 文件 describe('example', () => {...你可以完善测试用例, 或者可能有些文件(譬如 config)和代码分支并不需要测试, 可以将其在测试覆盖率结果中排除, 参考如下配置 忽略目录下所有文件 在 jest.config.js 中添加 collectCoverageFrom...和声明 并在 jest.config.js 中添加 preset: 'ts-jest' 将 plus.js 重命名为 plus.ts export default function plus(a: number...(less)$': '/jest.transformer.js', // 正则匹配, 处理 less 样式 }, 然后重新执行测试就可以了 处理 css in js 如果你使用了类似...linaria 是通过 babel 插件将其预编译为 class 名的, 这里可以 mock 一下 css 函数, 返回一个随机值作为 class 名 在根目录创建 jest.setup.js jest.mock

    4.2K30

    在 vue-test-utils 中 mock 全局对象

    掉 Vue.prototype 的简单方式,不但对测试用例适用,也可以为所有测试设置默认的 mock。...在本次测试中,虽然并不会真正关心翻译文件看起来什么样,不过还是看一看这次用到的: export default { "en": { helloWorld: "Hello world!"...(译注:通过这种方式就不能在单元测试中耦合与特定语言相关的内容了,因为翻译功能实际上已失效,也更无法处理可选参数等) 使用配置设置默认的 mocks 有时需要一个 mock 的默认值,这样就不用为每个测试用例都设置一遍了...Mock Value" 这个示例中用到了 Jest,所以我将把默认 mock 描述在 jest.init.js 文件中 -- 该文件会在测试运行前被自动加载。...同时我也会导入并应用此前用于示例的翻译对象。

    2.1K10

    React + Redux Testing Library 单元测试

    在同一个文件夹中创建一个 math.test.js 文件,在这里我们将使用 Jest 来测试 math.js 中定义的函数: image.png 然后运行 yarn test (添加 NPM Script...在单元测试中,通常我们希望将重点放在作为独立单元进行测试的组件上,并避免间接断言其子组件的行为。...从技术上讲,你可以在真实的浏览器中运行,但由于在不同平台上启动真实浏览器的复杂性,更建议使用 JSDOM 在虚拟浏览器环境中运行 Node 中的测试。...都被放在了合理的位置,承担不同的职责 ,这也使得对它们进行单元测试变得容易很多。...当测试 action 的时候,我们需要增加一个 mocking 服务层——例如,我们可以把 API 调用抽象成服务,然后在测试文件中用 mock 服务响应所期望的 API 调用。

    3K10

    Vue 应用单元测试的策略与实践 02 - 单元测试基础

    #--yes yarn add jest -D #--dev 然后创建一个 math.js 文件,输入一个我们稍后测试的 sum 函数: const sum = (a, b) => a + b module.exports...在同一个文件夹中创建一个 math.test.js 文件,在这里我们将使用 Jest 来测试 math.js 中定义的函数: const { sum } = require('....}; }); }); 我们可以看到 jest.mock() 方法中的第二个参数是一个函数,那么我们就可以完全接管整个 ..../sound-player 这个文件当中 export 出来的,而被 Mock 之后我们的测试就可以使用 Mock 所返回的数据或方法,从而保证模块所返回的内容是我们所期望的。...唯一需要注意的是, 额外的expect.assertions(number) 其实是验证在测试期间所调用的断言数量,这在测试多层异步代码时很有用,以确保实际调用回调中的断言次数。 意犹未尽吗?

    2.9K20
    领券