couchDB designDoc开发工作流程和版本控制

时间:2013-02-16 10:42:49

标签: javascript node.js couchdb couchapp

对于开发,我希望将构成couchDB设计文档的各种组件(viewslistsshows)作为单独的文件与我在dir中的其他开发代码一起保存以couchDB为例。 当我对更改感到满意时,我想使用couchapp.push发送到数据库,同时还能够对版本控制设计文档组件文件。

我在考虑使用节点模块'couchapp'和节点扫描目录及其子目录的.js文件,然后使用它们构建设计文档并上传到couchDB。 也许子目标结构如下:

designDocsJs
  |-- views
  |     |--view1.js
  |     |--view2.js
  |-- shows
  |-- lists

是否可以将map和reduce放在同一个文件中,例如。 'view1.js'或者他们是否需要位于单独的文件'view1-map.js''view1-reduce.js'中?

Curretnly我使用以下内容,但我不确定如何使用节点读取.js文件并将它们动态添加到ddoc.views {}? 任何指导都将受到赞赏,特别是使用javascript /节点解决方案。

var couchapp = require('couchapp')
    , path = require('path');

  ddoc = {
      _id: '_design/entitiesNew'
    , views: {}
    , lists: {}
    , shows: {} 
  }

  // node module exports
  module.exports = ddoc;

  // REPLACE ME WITH SOME WAY OF READING A
  // STRUCTURED DIR OF .JS FILES AND COMBINING
  // AS NECESSARY
  ddoc.views.byType = {
    map: function(doc) {
      emit(doc.type, null);
    },
    reduce: '_count'
  }

  couchapp.loadAttachments(ddoc, path.join(__dirname, '_attachments'));

然后:

$ cd path/to/here
$ mkdir _attachments
$ couchapp push updateCouchDbDesigndocs.js http://localhost:5984/databaseName

1 个答案:

答案 0 :(得分:4)

couchapp工具就是这样做的。我使用couchapp而不是其他脚本。

这是目录结构:

mycouchappdir
|-- views/
    |-- myview1/
       |-- map.js
       |-- reduce.js
|-- shows/
    |-- myshow1.js
    |-- myshow2.js
|-- _attachments/
    |-- myattachment.png

您的map.js文件如下所示:

function(doc) {
   emit(doc.type, null);
}

然后从couchapp push运行mycouchappdir


您可能还希望考虑将您的couchapps放在他们自己的存储库中。运行couchapp push始终会为设计文档创建新修订。因此,如果您为couchapp设置了不同的存储库,那么当您对存储库进行更改时,它就会对couchapp进行更改,您可以知道新版本与旧版本不同。