all files / src/commitizen/ commit.js

81.82% Statements 9/11
50% Branches 1/2
100% Functions 4/4
81.82% Lines 9/11
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                                                                                   
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() {
      done(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(template, overrideOptions) {
    
      // 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);
    }); 
  }
   
}