diff --git a/LAB-02.md b/LAB-02.md index 60881c7..6520275 100644 --- a/LAB-02.md +++ b/LAB-02.md @@ -13,13 +13,13 @@ * add your own gitignore * include a package.json * include the class eslint -* add a glup file +* add a gulp file ### Gulp Tasks * make a lint task for running eslint * make a test task for running mocha -* make a dev task that waches your files and runs the lint and test taks -* make a defalut task that runs your favorite task +* make a dev task that watches your files and runs the lint and test task +* make a default task that runs your favorite task ## Rubric: * Correct Submission: 2pts diff --git a/lab-elizabeth/.eslintrc b/lab-elizabeth/.eslintrc new file mode 100644 index 0000000..86e3575 --- /dev/null +++ b/lab-elizabeth/.eslintrc @@ -0,0 +1,24 @@ +{ + "rules": { + "comma-dangle": ["error", "always-multiline"], + "no-console": "off", + "indent": [ "error", 2 ], + "quotes": [ "error", "single" ], + "semi": ["error", "always"], + "linebreak-style": [ "error", "unix" ] + }, + "env": { + "es6": true, + "node": true, + "mocha": true, + "jasmine": true + }, + "globals": { + }, + "ecmaFeatures": { + "modules": true, + "experimentalObjectRestSpread": true, + "impliedStrict": true + }, + "extends": "eslint:recommended" +} diff --git a/lab-elizabeth/.gitignore b/lab-elizabeth/.gitignore new file mode 100644 index 0000000..1a89a33 --- /dev/null +++ b/lab-elizabeth/.gitignore @@ -0,0 +1,130 @@ + +# Created by https://www.gitignore.io/api/osx,linux,node,vim,sublimetext + +### OSX ### +*.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + + +# Thumbnails +._* + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.Spotlight-V100 +.TemporaryItems +.Trashes +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + + +### Linux ### +*~ + +# temporary files which can be created if a process still has a handle open of a deleted file +.fuse_hidden* + +# KDE directory preferences +.directory + +# Linux trash folder which might appear on any partition or disk +.Trash-* + + +### Node ### +# Logs +logs +*.log +npm-debug.log* + +# Runtime data +pids +*.pid +*.seed +*.pid.lock + +# Directory for instrumented libs generated by jscoverage/JSCover +lib-cov + +# Coverage directory used by tools like istanbul +coverage + +# nyc test coverage +.nyc_output + +# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) +.grunt + +# node-waf configuration +.lock-wscript + +# Compiled binary addons (http://nodejs.org/api/addons.html) +build/Release + +# Dependency directories +node_modules +jspm_packages + +# Optional npm cache directory +.npm + +# Optional eslint cache +.eslintcache + +# Optional REPL history +.node_repl_history + + +### Vim ### +# swap +[._]*.s[a-w][a-z] +[._]s[a-w][a-z] +# session +Session.vim +# temporary +.netrwhist +*~ +# auto-generated tag files +tags + + +### SublimeText ### +# cache files for sublime text +*.tmlanguage.cache +*.tmPreferences.cache +*.stTheme.cache + +# workspace files are user-specific +*.sublime-workspace + +# project files should be checked into the repository, unless a significant +# proportion of contributors will probably not be using SublimeText +# *.sublime-project + +# sftp configuration file +sftp-config.json + +# Package control specific files +Package Control.last-run +Package Control.ca-list +Package Control.ca-bundle +Package Control.system-ca-bundle +Package Control.cache/ +Package Control.ca-certs/ +bh_unicode_properties.cache + +# Sublime-github package stores a github token in this file +# https://packagecontrol.io/packages/sublime-github +GitHub.sublime-settings diff --git a/lab-elizabeth/gulpfile.js b/lab-elizabeth/gulpfile.js new file mode 100644 index 0000000..83e5853 --- /dev/null +++ b/lab-elizabeth/gulpfile.js @@ -0,0 +1,23 @@ +'use strict'; + +const gulp = require('gulp'); +const eslint = require('gulp-eslint'); +const mocha = require('gulp-mocha'); + +gulp.task('lint', function(){ + return gulp.src(['**/*.js', '!node_modules/**']) + .pipe(eslint()) + .pipe(eslint.format()) + .pipe(eslint.failAfterError()); +}); + +gulp.task('test', function(){ + gulp.src('./test/*-test.js', {read: false}) + .pipe(mocha({reporter: 'landing'})); +}); + +gulp.task('dev', function(){ + gulp.watch(['**/*.js', '!node_modules/**'], ['lint', 'test']); +}); + +gulp.task('default', ['test']); diff --git a/lab-elizabeth/index.js b/lab-elizabeth/index.js new file mode 100644 index 0000000..c3af9a3 --- /dev/null +++ b/lab-elizabeth/index.js @@ -0,0 +1,5 @@ +'use strict'; + +const greet = require('./lib/greet'); + +greet('liz'); diff --git a/lab-elizabeth/lib/greet.js b/lab-elizabeth/lib/greet.js new file mode 100644 index 0000000..7315cee --- /dev/null +++ b/lab-elizabeth/lib/greet.js @@ -0,0 +1,6 @@ +'use strict'; + +module.exports = function greet(name) { + if(!name) throw new Error('expected name'); + return `hello ${name}`; +}; diff --git a/lab-elizabeth/package.json b/lab-elizabeth/package.json new file mode 100644 index 0000000..ce0c59c --- /dev/null +++ b/lab-elizabeth/package.json @@ -0,0 +1,18 @@ +{ + "name": "lab-elizabeth", + "version": "1.0.0", + "description": "day 01 lab assignment", + "main": "index.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "author": "tenlia@hotmail.com", + "license": "MIT", + "devDependencies": { + "eslint": "^3.5.0", + "gulp": "^3.9.1", + "gulp-eslint": "^3.0.1", + "gulp-mocha": "^3.0.1", + "mocha": "^3.0.2" + } +} diff --git a/lab-elizabeth/test/greet-test.js b/lab-elizabeth/test/greet-test.js new file mode 100644 index 0000000..a26ea5b --- /dev/null +++ b/lab-elizabeth/test/greet-test.js @@ -0,0 +1,13 @@ +'use strict'; + +const greet = require('../lib/greet'); +const assert = require('assert'); + +describe('testing greet.js module', function(){ + it('should return hello lizzie', function(){ + assert.equal(greet('lizzie'), 'hello lizzie', 'expected "hello lizzie"'); + }); + it('should throw error for missing input', function(){ + assert.throws(greet, 'expected missing name error'); + }); +});