| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 | 
							- // Copyright (C) 2018 The Syncthing Authors.
 
- //
 
- // This Source Code Form is subject to the terms of the Mozilla Public
 
- // License, v. 2.0. If a copy of the MPL was not distributed with this file,
 
- // You can obtain one at https://mozilla.org/MPL/2.0/.
 
- package db
 
- import (
 
- 	"encoding/json"
 
- 	"io"
 
- 	"os"
 
- 	"github.com/syncthing/syncthing/lib/db/backend"
 
- )
 
- // writeJSONS serializes the database to a JSON stream that can be checked
 
- // in to the repo and used for tests.
 
- func writeJSONS(w io.Writer, db backend.Backend) {
 
- 	it, err := db.NewPrefixIterator(nil)
 
- 	if err != nil {
 
- 		panic(err)
 
- 	}
 
- 	defer it.Release()
 
- 	enc := json.NewEncoder(w)
 
- 	for it.Next() {
 
- 		err := enc.Encode(map[string][]byte{
 
- 			"k": it.Key(),
 
- 			"v": it.Value(),
 
- 		})
 
- 		if err != nil {
 
- 			panic(err)
 
- 		}
 
- 	}
 
- }
 
- // we know this function isn't generally used, nonetheless we want it in
 
- // here and the linter to not complain.
 
- var _ = writeJSONS
 
- // openJSONS reads a JSON stream file into a backend DB
 
- func openJSONS(file string) (backend.Backend, error) {
 
- 	fd, err := os.Open(file)
 
- 	if err != nil {
 
- 		return nil, err
 
- 	}
 
- 	dec := json.NewDecoder(fd)
 
- 	db := backend.OpenMemory()
 
- 	for {
 
- 		var row map[string][]byte
 
- 		err := dec.Decode(&row)
 
- 		if err == io.EOF {
 
- 			break
 
- 		} else if err != nil {
 
- 			return nil, err
 
- 		}
 
- 		if err := db.Put(row["k"], row["v"]); err != nil {
 
- 			return nil, err
 
- 		}
 
- 	}
 
- 	return db, nil
 
- }
 
- // The following commented tests were used to generate jsons files to stdout for
 
- // future tests and are kept here for reference (reuse).
 
- // TestGenerateIgnoredFilesDB generates a database with files with invalid flags,
 
- // local and remote, in the format used in 0.14.48.
 
- // func TestGenerateIgnoredFilesDB(t *testing.T) {
 
- // 	db := OpenMemory()
 
- // 	fs := NewFileSet("test", fs.NewFilesystem(fs.FilesystemTypeBasic, "."), db)
 
- // 	fs.Update(protocol.LocalDeviceID, []protocol.FileInfo{
 
- // 		{ // invalid (ignored) file
 
- // 			Name:    "foo",
 
- // 			Type:    protocol.FileInfoTypeFile,
 
- // 			Invalid: true,
 
- // 			Version: protocol.Vector{Counters: []protocol.Counter{{ID: 1, Value: 1000}}},
 
- // 		},
 
- // 		{ // regular file
 
- // 			Name:    "bar",
 
- // 			Type:    protocol.FileInfoTypeFile,
 
- // 			Version: protocol.Vector{Counters: []protocol.Counter{{ID: 1, Value: 1001}}},
 
- // 		},
 
- // 	})
 
- // 	fs.Update(protocol.DeviceID{42}, []protocol.FileInfo{
 
- // 		{ // invalid file
 
- // 			Name:    "baz",
 
- // 			Type:    protocol.FileInfoTypeFile,
 
- // 			Invalid: true,
 
- // 			Version: protocol.Vector{Counters: []protocol.Counter{{ID: 42, Value: 1000}}},
 
- // 		},
 
- // 		{ // regular file
 
- // 			Name:    "quux",
 
- // 			Type:    protocol.FileInfoTypeFile,
 
- // 			Version: protocol.Vector{Counters: []protocol.Counter{{ID: 42, Value: 1002}}},
 
- // 		},
 
- // 	})
 
- // 	writeJSONS(os.Stdout, db.DB)
 
- // }
 
- // TestGenerateUpdate0to3DB generates a database with files with invalid flags, prefixed
 
- // by a slash and other files to test database migration from version 0 to 3, in the
 
- // format used in 0.14.45.
 
- // func TestGenerateUpdate0to3DB(t *testing.T) {
 
- // 	db := OpenMemory()
 
- // 	fs := NewFileSet(update0to3Folder, fs.NewFilesystem(fs.FilesystemTypeBasic, "."), db)
 
- // 	for devID, files := range haveUpdate0to3 {
 
- // 		fs.Update(devID, files)
 
- // 	}
 
- // 	writeJSONS(os.Stdout, db.DB)
 
- // }
 
 
  |