在windows上部署使用Redis

2014-07-05 · 12 min read

这两天在重新做公司内网首页,信息都是从别的系统获取的,产品原来打算直接上静态页,jsonp 异步取数据。但是一来 jsonp 比较坑(一直不喜欢),二来整个页面的数据都异步获取的话,刚刚打开页面的时候会空白一片,体验极其差。所以决定用 node.js + express + redis 简单搞下。今天早晨一直在折腾 Redis,看了挺多文章,可能是版本或者其他的原因,我遇到的问题他们都没有提,不过终于还是部署上了,下面把过程写下给大家参考。

使用 tictac.js 实现倒计时

2014-06-05 · 19 min read

Tictac.js(GitHubDemo)是应项目需要写的一个倒计时组件,比较简洁(或者说简单),主要功能是:

  • “当前时间”可配置,可以使用服务端时间
  • 可以设定一个时间间隔,周期性执行回调函数
  • 注册任意多个“计时器”实例,每个计时器结束会触发回调函数
  • 自定义倒计时的时间展示格式

使用 Travis CI 进行Javascript集成测试

2014-06-05 · 7 min read

前面一直在学习 Jasmine,并且很简单很简单的测试了jqPaginator的代码,这一次来看看怎么使用 Travis CI 对 Github 的项目进行自动化集成测试。借用 wikipedia 的话介绍下:

Travis CI 是在软件开发领域中的一个在线的,分布式的持续集成服务,用来构建及测试在 GitHub 托管的代码

虽然 jqPaginator 的测试还没写好(测试真是门学问,还需下功夫好好研究),但忍不住先来看看怎么用 Travis CI。

Javascript测试框架Jasmine(六):异步代码测试

2014-06-05 · 11 min read

模拟 Timeout

Jasmine Clock 可以用来测试setTimeoutsetInterval 的回调操作。它使回调函数同步执行,当 Clock 的时间超过 timer 的时间,回调函数会被触发一次。这使依赖于时间的代码更加易于测试。

Jasmine Clock 使用jasmine.clock().install 在需要调用 timer 函数的 spec 和 suite 中初始化。在执行完测试的时候,一定要卸载 Clock 来还原 timer 函数。使用jasmine.clock().tick 设置时间以使注册的回调触发。

Javascript测试框架Jasmine(五):Spies

2014-06-05 · 22 min read

Spies 是 Jasmine 里面比较高端的方法,可以用来模拟函数的执行,以达到隔离复杂依赖的效果。例如,你要测试列表的处理是否正确,但是数据是异步请求接口取得的,这时你就可以使用 Spies,模拟返回各种不同的数据进行测试。

spy 可以保存任何函数的调用记录和输入的参数,spy 只能存在于 describe 和 it 中,在 spec 执行完之后销毁。先说两个针对 spies 的 Matcher,toHaveBeenCalled 用来测试函数是否被调用过;toHaveBeenCalledWith 用来测试函数被调用时的参数列表,匹配的话返回true ,看个例子:

Javascript测试框架Jasmine(四):自定义Matcher

2014-06-05 · 16 min read

一个项目常常需要封装自定义的 Matcher 来在多个 spec 中使用,这次讲下怎么写兼容 Jasmine 的自定义 Matcher。

自定义的 Matcher 从本质上讲是一个对比函数,它的函数名就是暴露给 expect 调用的名称,它接受actual 值和expected 值。这个函数会传入 Jasmine 作用域中,可以在beforeEach 中调用到。每次 spec 执行完后,都会把自定义 Matchers 卸载,下面看个简单例子:

Javascript测试框架Jasmine(三):Setup、Teardown、嵌套describe等

2014-06-05 · 15 min read

上一篇把 Matcher 说了说,本来该说自定义 Matcher 的,但是发现有些七七八八的细节没讲,那就今天先把这些基础说了。

Setup and Teardown

Setup 和 Teardown 可以帮助 Suite 执行一些重复的代码,Jasmine 提供了beforeEachafterEach 函数。很显然,beforeEach 在 describe 中的任何 spec 执行之前运行,afterEach 在任何 spec 执行之后运行。具体的逻辑看 Demo 就一目了然了:

Javascript测试框架Jasmine(二):Matchers

2014-06-05 · 15 min read

上一篇稍微介绍了一下,这一篇讲讲 Matcher。在 Jasmine 中,每个 Matcher 实现一个“期望值”和“实际值”的布尔判断,Jasmine 会根据 Mather 判断 expectation 是true 还是false ,然后决定 spec 是测试通过还是失败。所有 Matcher 可以通过not 执行否定判断。例如:

it('not示例', function () {
  expect(false).not.toBe(true)
})