mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-25 10:04:14 +03:00
6bf4b3e1d8
SPDX License List is a list of (common) open source licenses that can be referred to by a “short identifier”. It has several advantages compared to the common "license header texts" usually found in source files. Some of the advantages: * It is precise; there is no ambiguity due to variations in license header text * It is language neutral * It is easy to machine process * It is concise * It is simple and can be used without much cost in interpreted environments like java Script, etc. * An SPDX license identifier is immutable. * It provides simple guidance for developers who want to make sure the license for their code is respected See http://spdx.org for further reading. Signed-off-by: Marcus Folkesson <marcus.folkesson@gmail.com> Closes: #1439 Approved by: cgwalters
117 lines
4.1 KiB
JavaScript
Executable File
117 lines
4.1 KiB
JavaScript
Executable File
#!/usr/bin/env gjs
|
|
//
|
|
// Copyright (C) 2013 Colin Walters <walters@verbum.org>
|
|
// Copyright (C) 2017 Dan Nicholson <nicholson@endlessm.com>
|
|
//
|
|
// SPDX-License-Identifier: LGPL-2.0+
|
|
//
|
|
// This library is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
// License as published by the Free Software Foundation; either
|
|
// version 2 of the License, or (at your option) any later version.
|
|
//
|
|
// This library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
// License along with this library; if not, write to the
|
|
// Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
// Boston, MA 02111-1307, USA.
|
|
|
|
const GLib = imports.gi.GLib;
|
|
const Gio = imports.gi.Gio;
|
|
const OSTree = imports.gi.OSTree;
|
|
|
|
function assertEquals(a, b) {
|
|
if (a != b)
|
|
throw new Error("assertion failed " + JSON.stringify(a) + " == " + JSON.stringify(b));
|
|
}
|
|
|
|
function assertNotEquals(a, b) {
|
|
if (a == b)
|
|
throw new Error("assertion failed " + JSON.stringify(a) + " != " + JSON.stringify(b));
|
|
}
|
|
|
|
print('1..6')
|
|
|
|
let remotesDir = Gio.File.new_for_path('remotes.d');
|
|
remotesDir.make_directory(null);
|
|
|
|
let remoteConfig = GLib.KeyFile.new()
|
|
remoteConfig.set_value('remote "foo"', 'url', 'http://foo')
|
|
|
|
let remoteConfigFile = remotesDir.get_child('foo.conf')
|
|
remoteConfig.save_to_file(remoteConfigFile.get_path())
|
|
|
|
// Use the full Repo constructor to set remotes-config-dir
|
|
let repoFile = Gio.File.new_for_path('repo');
|
|
let repo = new OSTree.Repo({path: repoFile,
|
|
remotes_config_dir: remotesDir.get_path()});
|
|
repo.create(OSTree.RepoMode.ARCHIVE_Z2, null);
|
|
repo.open(null);
|
|
|
|
// See if the remotes.d remote exists
|
|
let remotes = repo.remote_list()
|
|
assertNotEquals(remotes.indexOf('foo'), -1);
|
|
|
|
print("ok read-remotes-config-dir");
|
|
|
|
// Adding a remote should not go in the remotes.d dir unless this is a
|
|
// system repo or add-remotes-config-dir is set to true
|
|
repo.remote_add('bar', 'http://bar', null, null);
|
|
remotes = repo.remote_list()
|
|
assertNotEquals(remotes.indexOf('bar'), -1);
|
|
assertEquals(remotesDir.get_child('bar.conf').query_exists(null), false);
|
|
|
|
print("ok add-not-in-remotes-config-dir");
|
|
|
|
// Removing the remotes.d remote should delete the conf file
|
|
repo.remote_delete('foo', null);
|
|
remotes = repo.remote_list()
|
|
assertEquals(remotes.indexOf('foo'), -1);
|
|
assertEquals(remotesDir.get_child('foo.conf').query_exists(null), false);
|
|
|
|
print("ok delete-in-remotes-config-dir");
|
|
|
|
// Set add-remotes-config-dir to true and check that a remote gets added
|
|
// in the config dir
|
|
let repoConfig = repo.copy_config();
|
|
repoConfig.set_boolean('core', 'add-remotes-config-dir', true);
|
|
repo.write_config(repoConfig);
|
|
repo.reload_config(null);
|
|
repo.remote_add('baz', 'http://baz', null, null);
|
|
remotes = repo.remote_list()
|
|
assertNotEquals(remotes.indexOf('baz'), -1);
|
|
assertEquals(remotesDir.get_child('baz.conf').query_exists(null), true);
|
|
|
|
print("ok add-in-remotes-config-dir");
|
|
|
|
// Trying to set a remote config option via write_config() for a remote
|
|
// defined in the config file should succeed
|
|
let [, gpg_verify] = repo.remote_get_gpg_verify('bar');
|
|
assertEquals(gpg_verify, true);
|
|
repoConfig = repo.copy_config();
|
|
repoConfig.set_boolean('remote "bar"', 'gpg-verify', false);
|
|
repo.write_config(repoConfig);
|
|
repo.reload_config(null);
|
|
[, gpg_verify] = repo.remote_get_gpg_verify('bar');
|
|
assertEquals(gpg_verify, false);
|
|
|
|
print("ok config-remote-in-config-file-succeeds");
|
|
|
|
// Trying to set a remote config option via write_config() for a remote
|
|
// defined in the config dir should fail with G_IO_ERROR_EXISTS
|
|
repoConfig = repo.copy_config();
|
|
repoConfig.set_boolean('remote "baz"', 'gpg-verify', false);
|
|
try {
|
|
if (repo.write_config(repoConfig))
|
|
throw new Error("config of remote in config dir should fail");
|
|
} catch (e) {
|
|
if (!(e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.EXISTS)))
|
|
throw e;
|
|
}
|
|
|
|
print("ok config-remote-in-config-dir-fails");
|