TDD初探 + git + NodeJS学习--(FrequencyNumber)


github地址:https://github.com/DaisyCJ/Frequency-Number.git

本次是用TDD(测试驱动开发Test-Driven Development)方法来实现一个简单的程序。编程工具是webstorm。nodeJS测试框架是jasmine。git创建代码库,保存每一次提交的代码版本。基本流程是单元测试实现-->功能代码实现-->jasmine测试-->git commit提交

命令行简单介绍

命令行 或 命令行界面,是一个基于文本的用来查看、 处理、 和操作您的计算机上的文件的应用程序。git和nodeJS都会用的命令行。笔者用的Windows系统,使用快捷键win+R,再输入cmd即可。
可通过网站简单了解:https://tutorial.djangogirls.org/zh/intro_to_command_line/

git基础

__1. 介绍、安装、教程 __
安装包、安装教程: http://www.runoob.com/git/git-install-setup.html
快速入门:http://codecloud.net/4635.html
这个比较详细:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/001373962845513aefd77a99f4145f0a2c7a7ca057e7570000

2. 本次练习需要用到的命令(都是很常用,很重要的)
git init------------------------------在当前目录新建一个Git代码库
git add [file1] [file2] ...---------添加指定文件到暂存区
git add .---------------------------添加当前目录的所有文件到暂存区
git commit -m [message]-----提交暂存区到仓库区
git status--------------------------显示有变更的文件
git log------------------------------显示当前分支的版本历史
git checkout [file]----------------恢复暂存区的指定文件到工作区
git checkout .---------------------恢复暂存区的所有文件到工作区
git reset----------------------------(回退到之前的版本)(用HEAD表示当前版本,HEAD表示上一个版本,HEAD^表示上上个版本)如回退到上一个:git reset --hard HEAD^

3. 深入学习
除了上述的一些简单的命令之外,git最大的优势在于其分布式,可在github代码库创建分支,多人参与编程,并将各种的修改提交到同一个远程代码库。本次练习中只运用到了一些简单的命令,没有涉及分布式,可自己尝试,深入学习。

NodeJS基础

  1. 介绍、安装、教程
    入门级新手必看:http://www.runoob.com/nodejs/nodejs-tutorial.html
  2. karme jasmine测试框架安装
    在命令行输入:npm install -g jasmine
    在联网的情况下,输入后会自动全局安装,之后就可以使用jasmine测试框架了。

创建代码库,初始化jasmine测试文件

在目标文件所在文件夹,直接点击右键进入git bush,在git init创建代码库即可

TDD初探 + git + NodeJS学习--(FrequencyNumber)_第1张图片
无标题.png

再告诉git你要使用jamine测试框架,jasmine init初始化。
接着进入webstorm码代码就可以啦,需要测试的时候在git里面输入jasmine就好,你也可以随时对代码进行提交。

TDD

TDD是什么?有什么特点?

  • 测试驱动开发(Test-Driven Development)的英文简称,是敏捷开发中的一项核心实践和技术,也是一种设计方法论。 TDD的原理是在开发功能代码之前,先编写单元测试用例代码,测试代码确定需要编写什么产品代码。

简单点说就是一个先写测试,再写实现代码,用剪单的方式让测试通过,之后再优化代码。把程序拆分成一个个功能来实现。

编程实现

Frequency Number需求:

  • 我想要一个nodejs小程序,
    它可以帮我处理一段字符串信息,这段字符串信息是由英文单词组成,每两个单词之间有空格,
    处理结果也为一段字符串,这个字符串应该每行只显示一个单词和它的数量,并且按出现频率倒序排列

example:

  • input:
“it was the age of wisdom it was the age of foolishness it is”
  • output
it 3
was 2
the 2
age 2
of 2 
wisdom 1
foolishness 1
is 1

任务分解
想要实现要求,需对测试字符串进行

  • 拆分
  • 分组
  • 单词统计
  • 按数量排序
  • 拼接输出

具体实现
可从测试空字符开始,为以上要求先写一个测试,在写功能代码,让测试通过,进而实现全部功能。

代码

//***test_spec.js***

var main= require('../../shixian.js');

describe("Word Frequency",function(){
    it("return empty string given empty string",function(){
        var result = main('');
        expect(result).toEqual('');
        });
    it("return string given one word",function(){
        var result = main('he');
        expect(result).toEqual('he 1');
       });
    it("return string given two different words",function(){
            var result = main('he is');
            expect(result).toEqual('he 1\r\nis 1');
       });
    it("return string given duplicated words",function(){
            var result = main('he he is');
            expect(result).toEqual('he 2\r\nis 1');
       });
    it("return string given words splited by multiple space",function(){
            var result = main('he    is');
            expect(result).toEqual('he 1\r\nis 1')
       });
    it("a test",function(){
        var result = main('it was the age of wisdom it was the age of foolishness it is');
        expect(result).toEqual('it 3\r\nwas 2\r\nthe 2\r\nage 2\r\nof 2\r\nwisdom 1\r\nfoolishness 1\r\nis 1')
    });
//***shixian.js***
var formatWordAndCount = function (words, count){
    return words + ' ' + count;
}

var group = function (wordArray ){
    return wordArray .reduce((array, word) =>{
        let entry = array.find((e) => e.word === word);
        if(entry){
            entry.count++;
            }
         else{
            array.push({word: word,count: 1});
         }
         return array;
     }, []);
};
var split = function (words){
    return words.split(/\s+/);
}

var sort = function (groupWords) {
    groupWords .sort((x, y) => y.count - x.count);
}

var format = function (groupWords) {
    return groupWords.map((e) => formatWordAndCount(e.word, e.count)).join('\r\n');
}
function main(words){
    if(words !== ''){
          let wordArray = split(words);
          let  groupWords = group(wordArray);
          sort(groupWords);
          return format(groupWords);
    }
    return '';
}
module.exports = main;

文件目录:


TDD初探 + git + NodeJS学习--(FrequencyNumber)_第2张图片
文件目录

git log 记录

TDD初探 + git + NodeJS学习--(FrequencyNumber)_第3张图片
git log 记录

总结

本次练习涉及很多以前没有接触过的新技术、新概念,导致开始不知道从哪里下手,花了很长时间配置安装。如何在信息泛滥的互联网搜索自己想要的信息,而不被一个又一个新概念牵着走,也是一个很重要的技能。从最简单的开始,安装、配置、HelloWorld、基本语法、跟着实现一个小程序,慢慢来,给自己逐渐增加信心想继续学下去。另外,当一个问题在网上找不到满意的资料,得不到解决,还是要厚着脸皮请教一些大神呀。

你可能感兴趣的:(TDD初探 + git + NodeJS学习--(FrequencyNumber))