Git Product home page Git Product logo

originator's Introduction

originator

Known Vulnerabilities

intent

This is currently intended to be cloned as a starter template for a new node module. It was created to serve as a utility/backup for my module template experiments and is a bit outdated now.

usage

git clone https://github.com/mdelucchi/originator.git your-module-name

npm scripts

watch - starts file watcher

lint - runs eslint on /src

test - runs tests and formats piped TAP output with tap-spec.

ci - Travis CI integration + zuul multi-framework & browser tests

cover - generates code coverage text-summary report in terminal

report - generates code coverage html report and opens it in browser

coveralls - runs code coverage and sends report to coveralls

zuul - runs browser tests via zuul at http://localhost:9966/__zuul

devDependencies:

  • babel - compiler for writing next generation JavaScript

  • babel-eslint - ESLint using Babel as the parser

  • babel-istanbul - excellent coverage tool

  • babelify - Browserify transform for Babel. Used in multi-framework testing with zuul.

  • blue-tape - substack's tape test runner with promise support

  • coveralls - test coverage and history statistics support for node.js

  • eslint - A fully pluggable tool for identifying and reporting on patterns in JavaScript.

  • eslint-config-xo - ESLint shareable config for XO

  • eslint-plugin-babel - an eslint rule plugin companion to babel-eslint

  • nsp - check for vulnerabilities

  • rimraf - remove stuff

  • tap-spec - formatted TAP output

  • zuul - multi-framework javascript browser testing

Travis CI / Sauce Connect Configuration

Sauce Connect - Used to create tunnel allowing Travis CI to utilize Sauce Labs, a browser and mobile testing platform.

If you plan to use Sauce Connect in your new module, be sure to sign up with Sauce Labs if you haven’t already (it’s free for Open Source projects), and get your access key from your account page.

Then you'll want to replace the secured access key in .travis.yml with your own. See the Getting Started guide on Travis for more info on setting this up.

Best bet if you're a new Travis and/or Sauce Labs user is to follow their steps to create a new .travis.yml file.

Publishing

When you are ready to publish a new version of your module, the following steps can be used:

  1. add and commit your changes via git
  2. npm version patch -m "Ugrade message..."
  3. npm publish

If publish is a success, the postpublish npm script will run git push origin master --follow-tags, pushing up and tagging your code properly.

If you run npm version patch before committing your changes, you'll get a message like npm ERR! Git working directory not clean.. Commit and retry.

originator's People

Contributors

dependabot[bot] avatar zanuka avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

originator's Issues

Fix coverage metrics

If you look at the coverage report, it actually isn't working correctly, because the 60% coverage is from just the file being included. If the tests are run we should be seeing 100% coverage.

turn into generator :: cli

make this more useful by making it a cli tool and supporting more languages:

  • updated node module support
  • dart package version
  • typescript version
  • go version

add shell install to readme

Shell Install

In your workspace, make a new directory and install via cURL:

mkdir [your-dir-name]
cd [your-dir-name]
curl -fsSL https://github.com/zanuka/originator/archive/master.tar.gz | tar -xz --strip-components=1 originator-master
npm i
git init

Lots of repetition in tasks

There's a lot of repetition in the tasks, especially around the test running. Ideally we could get that down a bit.

Updating readme usage

The usage section describes how to use the module, but in reality this module isn't meant to be installed or used in that way, so it's presently kind of misleading.

upgrade module to support Babel6

Acceptance criteria for migrating to Babel6:

  1. module source written in ES6
  2. module transpiled to ES5 w/ Babel6 and appropriate plugins/helpers/runtime
  3. module can be required via require
  4. module can be required via import
  5. dist/ to include uglified script for inline include

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.