- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的职能是:
const PhoneNumber = require('awesome-phonenumber');
const twilio = require('twilio')(process.env.TWILIO_ACCOUNT_SID, process.env.TWILIO_AUTH_TOKEN);
const { twiml } = require('twilio');
exports.incoming = (requestBody) => {
const MessagingResponse = twiml.MessagingResponse;
const VoiceResponse = twiml.VoiceResponse;
const pn = new PhoneNumber(requestBody.Body, 'US');
return global.db.Conference.create({})
.then((dbCreate) => {
conferenceId = dbCreate.id;
// Call originator
return twilio.calls.create({
to: requestBody.From,
from: requestBody.To,
url: `${process.env.API_URL}/calls/conference?id=${conferenceId}`
});
})
我的测试是:
const _ = require('lodash');
const sinon = require('sinon');
const twilio = require('twilio')(process.env.TWILIO_ACCOUNT_SID, process.env.TWILIO_AUTH_TOKEN);
const { twiml } = require('twilio');
const SmsController = require('../../../controllers/sms');
const twilioIncomingSmsReq = require('../../mocks/twilioIncomingSmsReq');
describe.only('Sms Controller', () => {
let messagingResponseMessageStub;
let conferenceCreateStub;
beforeEach(() => {
messagingResponseMessageStub = sinon.stub(twiml.MessagingResponse.prototype, 'message').returns(true);
conferenceCreateStub = sinon.stub(global.db.Conference, 'create').resolves({ id: 1 });
return;
});
afterEach(() => {
messagingResponseMessageStub.restore();
conferenceCreateStub.restore();
return;
});
it.only('should call the originator and recipient', () => {
let requestBody = _.clone(twilioIncomingSmsReq);
console.log(twilio.calls);
let twilioDialStub = sinon.stub(twilio.calls, 'create').resolves(true);
console.log(twilio.calls);
return SmsController.incoming(requestBody)
.then(() => {
sinon.assert.calledWith(twilioDialStub, {
to: requestBody.From,
from: requestBody.To,
url: `${process.env.API_URL}/calls?id=1`
});
sinon.assert.calledWith(twilioDialStub, {
to: '+number',
from: requestBody.From,
url: `${process.env.API_URL}/calls?id=1`
});
twilioDialStub.restore();
return;
});
});
});
但在我的代码中,实际的 twilion.calls.create
函数被调用。不是 stub 。我做错了什么?
最佳答案
twilio
引用这些模块中的不同对象。 require('twilio')
是工厂函数。即使使用相同的参数调用,require('twilio')(...) !== require('twilio')(...)
也会创建一个新对象。 .
考虑导出twilio
例如,至少出于测试目的:
const twilio = require('twilio')(process.env.TWILIO_ACCOUNT_SID,
...
exports.twilio = twilio;
关于node.js - 为什么 sinon 不取代实际的函数调用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52415151/
我有一个包含几行的 HTML 表格。 我最初为其中一些表格行 (TR) 提供了一个 ID,然后我将使用 javascript 通过一些新的动态内容来设置其中一些表格行的 INNERHTML。 但是,I
在以下(Clojure)SO问题中:my own interpose function as an exercise 接受的答案是这样的: Replace your recursive call wi
我目前正在使用 Delphi7 和 ASTA 来处理客户端服务器与 Advantage DB 的通信。 我正在转向 Rad Studio XE Enterprise,并希望切换到不同但相似的解决方案,
当我尝试更新软件包时,我总是收到这条消息,我通常只是继续进行,一切都会正常进行。但我担心我不小心创建了一个比我想要的复杂得多的 Anaconda 环境。此线程 ( What does "the fol
这个问题在这里已经有了答案: 关闭 13 年前。 Possible Duplicate: Why not use tables for layout in HTML? 我知道现在每个人都在关注 DI
作为一名 Java 后端开发,日常工作中免不了要生成数据库表对应的持久化对象 PO,操作数据库的接口 DAO,以及 CRUD 的 XML,也就是 mapper。 Mybatis Generator 是
我需要用 bitshift 替换 Java 中的 Math.pow。 for (int i = n - 1; i >= 0; i--) Math.pow(16, n - i - 1) 其中 n
我对 Oracle 还很陌生。 可以肯定地说LTRIM(RTRIM())完全可以被 TRIM() 取代如果我想替换 Oracle 11g 中的前导和尾随空格? 此外,当我尝试在使用 JPA 的查询中使
此应用程序包含activity_main.xml、mainactivit.java 和一个Fragment 类。activity_main.xml 在RelativeLayout 中有一个Button
我正在研究将 Weblogic 10.x 替换为用于开发机器的 Apache Tomcat,我非常感谢任何人可能有的任何见解或建议。 任何试图在生产 webapp 服务器怪物上进行开发工作的人可能都知
我有以下 JS 代码,我想用 $ 符号替换所有 ₪ (₪)。 $(this).html($(this).html().replace(/₪/g,'$')); 但是它没有做任何事情。我还尝试
执行此操作的正确方法是什么?我有一个 标签,我想显示 那是内联的。 最佳答案 display: inline 应该可以解决问题。它将使 表现得像任何内联元素。 关于html - CSS:取代 h1 换
我有一个问题 - 当我改变方向时,我的第二个 fragment (此时处于 Activity 状态)被第一个 fragment 取代。我从来没有这样的行为,如果能解决它怎么办? 主要 Activity
我有多个结构,其格式与传递给 encodeParams 函数的 MapParameters 相同。不幸的是,对这些结构使用该函数会产生不需要的编码,包括嵌入的结构名称。无论如何,我可以使用 refle
前言 打开Android架构组件页面,我们可以发现一些最新发布的jetpack组件,如Room,DataStore, Paging3,DataBinding 等都支持了Flow。Google开
我正在尝试不区分大小写的模式匹配。为了学习,我尝试了以下方法,发现很难分析正在发生的事情。 String x = "Hello"; String pattern = "(?i)";
这个问题在这里已经有了答案: Why aren't my absolutely/fixed-positioned elements located where I expect? (3 个答案)
我有以下形式的 HTML 布局 .. .. // content .. 两个 header 都是 position: fixed 并设置为 header 1 刚好在 header 2 上方。这两个 h
阅读中this c++17 最终特性的总结我对结构化绑定(bind)的部分感到有点惊讶(强调我的): structured bindings Until now, there was a known
我正在集成一个用早期 Swift 编写的库。由于该库与 Swift 4 的兼容版本不可用,我正在自己删除错误。 有这一行: let pathBounds = CGPathGetBoundingBox(
我是一名优秀的程序员,十分优秀!