From 0bf9d90590d98ced5556e5f36b88c771a65b73d1 Mon Sep 17 00:00:00 2001 From: Laurent Goderre Date: Fri, 1 Nov 2013 11:50:58 -0400 Subject: [PATCH] Implemented #2 --- .gitignore | 1 + Gruntfile.js | 48 +++++++-- README.md | 22 +++-- package.json | 25 +++-- server/Thumbs.db | Bin 0 -> 10752 bytes server/grunt-i18n-spreadsheet.csv | 9 ++ ...8n_gspreadsheet.js => i18n_spreadsheet.js} | 93 ++++++++++++++---- test/i18n_gspreadsheet_test.js | 34 ------- test/i18n_spreadsheet_test.js | 40 ++++++++ 9 files changed, 192 insertions(+), 80 deletions(-) create mode 100644 server/Thumbs.db create mode 100644 server/grunt-i18n-spreadsheet.csv rename tasks/{i18n_gspreadsheet.js => i18n_spreadsheet.js} (62%) delete mode 100644 test/i18n_gspreadsheet_test.js create mode 100644 test/i18n_spreadsheet_test.js diff --git a/.gitignore b/.gitignore index 2992095..8aadcc5 100644 --- a/.gitignore +++ b/.gitignore @@ -2,4 +2,5 @@ node_modules npm-debug.log tmp +tmp_* locales diff --git a/Gruntfile.js b/Gruntfile.js index 89136ec..05d5384 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -1,6 +1,6 @@ /* - * grunt-i18n-gspreadsheet - * https://github.com/theoephraim/grunt-i18n-gspreadsheet + * grunt-i18n-spreadsheet + * https://github.com/theoephraim/grunt-i18n-spreadsheet * * Copyright (c) 2013 Theo Ephraim * Licensed under the MIT license. @@ -25,17 +25,46 @@ module.exports = function(grunt) { // Before generating any new files, remove any previously-created files. clean: { - tests: ['tmp'], + tests: ['tmp_*'], }, + connect: { + server: { + options: { + port: 8080, + base: "server" + } + } + }, + // Configuration to be run (and then tested). - i18n_gspreadsheet: { - test_config: { + i18n_spreadsheet: { + gdocs_test_config: { + options: { + key_column: 'key', + output_dir: 'tmp_gdocs', + google_docs: { + // this document key points to the test file -- see readme for more info + document_key: '0Araic6gTol6SdEtwb1Badl92c2tlek45OUxJZDlyN2c' + } + } + }, + http_test_config: { + options: { + key_column: 'key', + output_dir: 'tmp_http', + http: { + url: 'http://localhost:8080/grunt-i18n-spreadsheet.csv' + } + } + }, + local_test_config: { options: { key_column: 'key', - output_dir: 'tmp', - // this document key points to the test file -- see readme for more info - document_key: '0Araic6gTol6SdEtwb1Badl92c2tlek45OUxJZDlyN2c' + output_dir: 'tmp_local', + local: { + src: 'server/grunt-i18n-spreadsheet.csv' + } } } }, @@ -53,11 +82,12 @@ module.exports = function(grunt) { // These plugins provide necessary tasks. grunt.loadNpmTasks('grunt-contrib-jshint'); grunt.loadNpmTasks('grunt-contrib-clean'); + grunt.loadNpmTasks('grunt-contrib-connect'); grunt.loadNpmTasks('grunt-contrib-nodeunit'); // Whenever the "test" task is run, first clean the "tmp" dir, then run this // plugin's task(s), then test the result. - grunt.registerTask('test', ['clean', 'i18n_gspreadsheet', 'nodeunit']); + grunt.registerTask('test', ['clean', 'connect', 'i18n_spreadsheet', 'nodeunit']); // By default, lint and run all tests. grunt.registerTask('default', ['jshint', 'test']); diff --git a/README.md b/README.md index d5868b3..8a8b3d9 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -# grunt-i18n-gspreadsheet +# grunt-i18n-spreadsheet > Grunt plugin to generate i18n locale files from a google spreadsheet @@ -8,23 +8,23 @@ This plugin requires Grunt `~0.4.1` If you haven't used [Grunt](http://gruntjs.com/) before, be sure to check out the [Getting Started](http://gruntjs.com/getting-started) guide, as it explains how to create a [Gruntfile](http://gruntjs.com/sample-gruntfile) as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command: ```shell -npm install grunt-i18n-gspreadsheet --save-dev +npm install grunt-i18n-spreadsheet --save-dev ``` Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript: ```js -grunt.loadNpmTasks('grunt-i18n-gspreadsheet'); +grunt.loadNpmTasks('grunt-i18n-spreadsheet'); ``` -## The "i18n_gspreadsheet" task +## The "i18n_spreadsheet" task ### Overview -In your project's Gruntfile, add a section named `i18n_gspreadsheet` to the data object passed into `grunt.initConfig()`. +In your project's Gruntfile, add a section named `i18n_spreadsheet` to the data object passed into `grunt.initConfig()`. ```js grunt.initConfig({ - i18n_gspreadsheet: { + i18n_spreadsheet: { options: { // Task-specific options go here. }, @@ -87,12 +87,14 @@ Most likely, you will just be writing a single set of locale files from a single ```js grunt.initConfig({ - i18n_gspreadsheet: { + i18n_spreadsheet: { my_config: { options: { - google_account: 'my-username@google.com', - google_password: 'MySuperSecretPassword', - document_key: '0Araic6gTol6SdEtwb1Badl92c2tlek45OUxJZDlyN2c' + google_docs: { + google_account: 'my-username@google.com', + google_password: 'MySuperSecretPassword', + document_key: '0Araic6gTol6SdEtwb1Badl92c2tlek45OUxJZDlyN2c' + } } } }, diff --git a/package.json b/package.json index 50e998a..9af95d6 100644 --- a/package.json +++ b/package.json @@ -1,23 +1,23 @@ { - "name": "grunt-i18n-gspreadsheet", + "name": "grunt-i18n-spreadsheet", "description": "Grunt plugin to generate i18n locale files from a google spreadsheet", "version": "0.1.5", - "homepage": "https://github.com/theoephraim/grunt-i18n-gspreadsheet", + "homepage": "https://github.com/theoephraim/grunt-i18n-spreadsheet", "author": { "name": "Theo Ephraim", "email": "theo@busbud.com" }, "repository": { "type": "git", - "url": "git://github.com/theoephraim/grunt-i18n-gspreadsheet.git" + "url": "git://github.com/theoephraim/grunt-i18n-spreadsheet.git" }, "bugs": { - "url": "https://github.com/theoephraim/grunt-i18n-gspreadsheet/issues" + "url": "https://github.com/theoephraim/grunt-i18n-spreadsheet/issues" }, "licenses": [ { "type": "MIT", - "url": "https://github.com/theoephraim/grunt-i18n-gspreadsheet/blob/master/LICENSE-MIT" + "url": "https://github.com/theoephraim/grunt-i18n-spreadsheet/blob/master/LICENSE-MIT" } ], "main": "Gruntfile.js", @@ -31,18 +31,27 @@ "grunt-contrib-jshint": "~0.6.0", "grunt-contrib-clean": "~0.4.0", "grunt-contrib-nodeunit": "~0.2.0", - "grunt": "~0.4.1" + "grunt": "~0.4.1", + "grunt-contrib-connect": "~0.5.0" }, "peerDependencies": { "grunt": "~0.4.1" }, "keywords": [ - "gruntplugin", "grunt", "i18n", "google", "spreadsheet", "gdocs", "locale" + "gruntplugin", + "grunt", + "i18n", + "google", + "spreadsheet", + "gdocs", + "locale" ], "dependencies": { "google-spreadsheet": "~0.2.5", "step": "0.0.5", "underscore": "~1.5.2", - "mkdirp": "~0.3.5" + "mkdirp": "~0.3.5", + "request": "~2.27.0", + "csv": "~0.3.6" } } diff --git a/server/Thumbs.db b/server/Thumbs.db new file mode 100644 index 0000000000000000000000000000000000000000..7593909f975b0a686c1e899372409de388bfadb0 GIT binary patch literal 10752 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