]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/commitdiff
Add tag search support to server
authorChocobozzz <florian.bigard@gmail.com>
Mon, 6 Jun 2016 12:54:52 +0000 (14:54 +0200)
committerChocobozzz <florian.bigard@gmail.com>
Mon, 6 Jun 2016 12:54:52 +0000 (14:54 +0200)
server/initializers/constants.js
server/models/videos.js
server/tests/api/singlePod.js

index 97d22abdb52979489db81f19139fece9ed365699..c6a6ac96667a70649827df08755f45596a400b0f 100644 (file)
@@ -23,7 +23,7 @@ let REQUEST_RETRIES = 10
 
 // Sortable columns per schema
 const SEARCHABLE_COLUMNS = {
-  VIDEOS: [ 'name', 'magnetUri', 'podUrl', 'author' ]
+  VIDEOS: [ 'name', 'magnetUri', 'podUrl', 'author', 'tags' ]
 }
 
 // Sortable columns per schema
index f4658c371fec2a1e0153a3dd238cc9abad70f296..d6b743c7c46fe4db7ae5e0332f56d6adfe072289 100644 (file)
@@ -128,7 +128,7 @@ function removeByIds (ids, callback) {
 function search (value, field, start, count, sort, callback) {
   const query = {}
   // Make an exact search with the magnet
-  if (field === 'magnetUri') {
+  if (field === 'magnetUri' || field === 'tags') {
     query[field] = value
   } else {
     query[field] = new RegExp(value)
index ef882b08075038e0a1bc946cff515180ce14b929..5fcf5557f8747c52ce1144d4170b5433d385c3ef 100644 (file)
@@ -187,6 +187,32 @@ describe('Test a single pod', function () {
     })
   })
 
+  it('Should search the video by tag', function (done) {
+    utils.searchVideo(server.url, 'tag1', 'tags', function (err, res) {
+      if (err) throw err
+
+      expect(res.body.total).to.equal(1)
+      expect(res.body.data).to.be.an('array')
+      expect(res.body.data.length).to.equal(1)
+
+      const video = res.body.data[0]
+      expect(video.name).to.equal('my super name')
+      expect(video.description).to.equal('my super description')
+      expect(video.podUrl).to.equal('localhost:9001')
+      expect(video.author).to.equal('root')
+      expect(video.isLocal).to.be.true
+      expect(video.tags).to.deep.equal([ 'tag1', 'tag2', 'tag3' ])
+      expect(utils.dateIsValid(video.createdDate)).to.be.true
+
+      utils.testImage(server.url, 'video_short.webm', video.thumbnailPath, function (err, test) {
+        if (err) throw err
+        expect(test).to.equal(true)
+
+        done()
+      })
+    })
+  })
+
   it('Should not find a search by name by default', function (done) {
     utils.searchVideo(server.url, 'hello', function (err, res) {
       if (err) throw err
@@ -211,6 +237,18 @@ describe('Test a single pod', function () {
     })
   })
 
+  it('Should not find a search by tag', function (done) {
+    utils.searchVideo(server.url, 'tag', 'tags', function (err, res) {
+      if (err) throw err
+
+      expect(res.body.total).to.equal(0)
+      expect(res.body.data).to.be.an('array')
+      expect(res.body.data.length).to.equal(0)
+
+      done()
+    })
+  })
+
   it('Should remove the video', function (done) {
     utils.removeVideo(server.url, server.accessToken, videoId, function (err) {
       if (err) throw err