all files / src/commitizen/ commit.js

100% Statements 5/5
50% Branches 3/6
100% Functions 4/4
100% Lines 5/5
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62                                                                                                                 
import path from 'path';
 
import homeOrTmp from 'home-or-tmp';
import dedent from 'dedent';
import {commit as gitCommit, log} from '../git';
import * as cache from './cache';
 
export default commit;
 
/**
 * Takes all of the final inputs needed in order to make dispatch a git commit
 */
function dispatchGitCommit(sh, repoPath, template, options, overrideOptions, done) {
    // Commit the user input -- side effect that we'll test
    gitCommit(sh, repoPath, template, { ...options, ...overrideOptions }, function(error) {
      done(error, template);
    });
}
 
 /**
  * Asynchronously commits files using commitizen
  */
function commit(sh, inquirer, repoPath, prompter, options, done) {
  
  var cachePath = path.join(homeOrTmp, 'commitizen.json');
  
  Iif(options.retryLastCommit) {
    
    console.log('Retrying last commit attempt.');
    
    // We want to use the last commit instead of the current commit,
    // so lets override some options using the values from cache.
    let {
      options: retryOptions,
      overrideOptions: retryOverrideOptions,
      template: retryTemplate
    } = cache.getCacheValueSync(cachePath, repoPath);
    dispatchGitCommit(sh, repoPath, retryTemplate, retryOptions, retryOverrideOptions, done);
    
  } else {
    // Get user input -- side effect that is hard to test
    prompter(inquirer, function(error, template, overrideOptions) {
      // Allow adapters to error out
      // (error: Error?, template: String, overrideOptions: Object)
      Eif (!(error instanceof Error)) {
        overrideOptions = template;
        template = error;
        error = null;
      }
 
      Iif (error) {
        return done(error);
      }
 
      // We don't want to add retries to the cache, only actual commands
      cache.setCacheValueSync(cachePath, repoPath, { template, options, overrideOptions });
      dispatchGitCommit(sh, repoPath, template, options, overrideOptions, done);
    });
  }
   
}