core: remove HEAD file, use branches instead

HEAD in git describes a working copy, and we don't have those.
Instead, default to a "master" branch.  This also lets us support
multiple branches.
This commit is contained in:
Colin Walters 2011-10-27 09:21:07 -04:00
parent 6924e79e60
commit 7ca1c3d2e7
16 changed files with 319 additions and 190 deletions

View File

@ -56,12 +56,11 @@ typedef struct _OstreeRepoPrivate OstreeRepoPrivate;
struct _OstreeRepoPrivate {
char *path;
GFile *repo_file;
char *head_ref_path;
GFile *local_heads_dir;
char *objects_path;
char *config_path;
gboolean inited;
char *current_head;
GKeyFile *config;
};
@ -74,10 +73,9 @@ ostree_repo_finalize (GObject *object)
g_free (priv->path);
g_clear_object (&priv->repo_file);
g_free (priv->head_ref_path);
g_clear_object (&priv->local_heads_dir);
g_free (priv->objects_path);
g_free (priv->config_path);
g_free (priv->current_head);
if (priv->config)
g_key_file_free (priv->config);
@ -141,8 +139,8 @@ ostree_repo_constructor (GType gtype,
g_assert (priv->path != NULL);
priv->repo_file = ot_util_new_file_for_path (priv->path);
priv->local_heads_dir = g_file_resolve_relative_path (priv->repo_file, "refs/heads");
priv->head_ref_path = g_build_filename (priv->path, "HEAD", NULL);
priv->objects_path = g_build_filename (priv->path, "objects", NULL);
priv->config_path = g_build_filename (priv->path, "config", NULL);
@ -182,17 +180,37 @@ ostree_repo_new (const char *path)
}
static gboolean
parse_checksum_file (OstreeRepo *self,
validate_checksum_string (const char *sha256,
GError **error)
{
if (strlen (sha256) != 64)
{
g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
"Invalid rev '%s'", sha256);
return FALSE;
}
return TRUE;
}
static gboolean
parse_rev_file (OstreeRepo *self,
const char *path,
char **sha256,
GError **error) G_GNUC_UNUSED;
static gboolean
parse_rev_file (OstreeRepo *self,
const char *path,
char **sha256,
GError **error)
{
OstreeRepoPrivate *priv = GET_PRIVATE (self);
GError *temp_error = NULL;
gboolean ret = FALSE;
char *ret_sha256 = NULL;
char *rev = NULL;
ret_sha256 = ot_util_get_file_contents_utf8 (path, &temp_error);
if (ret_sha256 == NULL)
rev = ot_util_get_file_contents_utf8 (path, &temp_error);
if (rev == NULL)
{
if (g_error_matches (temp_error, G_FILE_ERROR, G_FILE_ERROR_NOENT))
{
@ -206,31 +224,136 @@ parse_checksum_file (OstreeRepo *self,
}
else
{
g_strchomp (ret_sha256);
g_strchomp (rev);
}
*sha256 = ret_sha256;
if (g_str_has_prefix (rev, "ref: "))
{
GFile *ref;
char *ref_path;
char *ref_sha256;
gboolean subret;
ref = g_file_resolve_relative_path (priv->local_heads_dir, rev + 5);
ref_path = g_file_get_path (ref);
subret = parse_rev_file (self, ref_path, &ref_sha256, error);
g_clear_object (&ref);
g_free (ref_path);
if (!subret)
{
g_free (ref_sha256);
goto out;
}
g_free (rev);
rev = ref_sha256;
}
else
{
if (!validate_checksum_string (rev, error))
goto out;
}
*sha256 = rev;
rev = NULL;
ret = TRUE;
out:
g_free (rev);
return ret;
}
static gboolean
write_checksum_file (const char *path,
resolve_rev (OstreeRepo *self,
const char *rev,
gboolean allow_noent,
char **sha256,
GError **error)
{
OstreeRepoPrivate *priv = GET_PRIVATE (self);
gboolean ret = FALSE;
char *ret_rev = NULL;
GFile *child = NULL;
char *child_path = NULL;
GError *temp_error = NULL;
if (strlen (rev) == 64)
{
ret_rev = g_strdup (rev);
}
else
{
child = g_file_get_child (priv->local_heads_dir, rev);
child_path = g_file_get_path (child);
if (!ot_util_gfile_load_contents_utf8 (child, NULL, &ret_rev, NULL, &temp_error))
{
if (allow_noent && g_error_matches (temp_error, G_IO_ERROR, G_IO_ERROR_NOT_FOUND))
{
g_free (ret_rev);
ret_rev = NULL;
}
else
{
g_propagate_error (error, temp_error);
g_prefix_error (error, "Couldn't open ref '%s': ", child_path);
goto out;
}
}
else
{
g_strchomp (ret_rev);
if (!validate_checksum_string (ret_rev, error))
goto out;
}
}
*sha256 = ret_rev;
ret_rev = NULL;
ret = TRUE;
out:
g_clear_object (&child);
g_free (child_path);
g_free (ret_rev);
return ret;
}
gboolean
ostree_repo_resolve_rev (OstreeRepo *self,
const char *rev,
char **sha256,
GError **error)
{
return resolve_rev (self, rev, FALSE, sha256, error);
}
static gboolean
write_checksum_file (GFile *parentdir,
const char *name,
const char *sha256,
GError **error)
{
gboolean ret = FALSE;
char *buf = NULL;
GFile *child = NULL;
GOutputStream *out = NULL;
gsize bytes_written;
buf = g_strconcat (sha256, "\n", NULL);
child = g_file_get_child (parentdir, name);
if (!g_file_set_contents (path, buf, -1, error))
if ((out = (GOutputStream*)g_file_replace (child, NULL, FALSE, 0, NULL, error)) == NULL)
goto out;
if (!g_output_stream_write_all (out, sha256, strlen (sha256), &bytes_written, NULL, error))
goto out;
if (!g_output_stream_write_all (out, "\n", 1, &bytes_written, NULL, error))
goto out;
if (!g_output_stream_close (out, NULL, error))
goto out;
ret = TRUE;
out:
g_free (buf);
g_clear_object (&child);
g_clear_object (&out);
return ret;
}
@ -253,9 +376,6 @@ ostree_repo_check (OstreeRepo *self, GError **error)
goto out;
}
if (!parse_checksum_file (self, priv->head_ref_path, &priv->current_head, error))
goto out;
priv->config = g_key_file_new ();
if (!g_key_file_load_from_file (priv->config, priv->config_path, 0, error))
{
@ -789,7 +909,6 @@ load_commit_and_trees (OstreeRepo *self,
ParsedDirectoryData **out_root_data,
GError **error)
{
OstreeRepoPrivate *priv = GET_PRIVATE (self);
GVariant *ret_commit = NULL;
ParsedDirectoryData *ret_root_data = NULL;
ParsedTreeData *tree_data = NULL;
@ -799,13 +918,6 @@ load_commit_and_trees (OstreeRepo *self,
const char *tree_contents_checksum;
const char *tree_meta_checksum;
if (!priv->current_head)
{
g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED,
"Can't load current commit; no HEAD reference");
goto out;
}
if (!load_gvariant_object (self, OSTREE_SERIALIZED_COMMIT_VARIANT,
commit_sha256, &ret_commit, error))
goto out;
@ -1256,6 +1368,8 @@ add_files_to_tree_and_import (OstreeRepo *self,
static gboolean
commit_parsed_tree (OstreeRepo *self,
const char *branch,
const char *parent,
const char *subject,
const char *body,
GVariant *metadata,
@ -1270,6 +1384,9 @@ commit_parsed_tree (OstreeRepo *self,
GVariant *commit = NULL;
GDateTime *now = NULL;
g_assert (branch != NULL);
g_assert (subject != NULL);
if (!import_parsed_tree (self, root->tree_data, &root_checksum, error))
goto out;
@ -1277,7 +1394,7 @@ commit_parsed_tree (OstreeRepo *self,
commit = g_variant_new ("(u@a{sv}ssstss)",
OSTREE_COMMIT_VERSION,
create_empty_gvariant_dict (),
priv->current_head ? priv->current_head : "",
parent ? parent : "",
subject, body ? body : "",
g_date_time_to_unix (now) / G_TIME_SPAN_SECOND,
g_checksum_get_string (root_checksum),
@ -1286,12 +1403,9 @@ commit_parsed_tree (OstreeRepo *self,
commit, &ret_commit, error))
goto out;
if (!write_checksum_file (priv->head_ref_path, g_checksum_get_string (ret_commit), error))
if (!write_checksum_file (priv->local_heads_dir, branch, g_checksum_get_string (ret_commit), error))
goto out;
g_free (priv->current_head);
priv->current_head = g_strdup (g_checksum_get_string (ret_commit));
ret = TRUE;
*out_commit = ret_commit;
out:
@ -1338,6 +1452,7 @@ import_root (OstreeRepo *self,
gboolean
ostree_repo_commit (OstreeRepo *self,
const char *branch,
const char *subject,
const char *body,
GVariant *metadata,
@ -1354,13 +1469,20 @@ ostree_repo_commit (OstreeRepo *self,
GChecksum *ret_commit_checksum = NULL;
GVariant *root_metadata = NULL;
GChecksum *root_meta_checksum = NULL;
char *current_head = NULL;
g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
g_return_val_if_fail (priv->inited, FALSE);
if (priv->current_head)
if (branch == NULL)
branch = "master";
if (!resolve_rev (self, branch, TRUE, &current_head, error))
goto out;
if (current_head)
{
if (!load_commit_and_trees (self, priv->current_head, &previous_commit, &root, error))
if (!load_commit_and_trees (self, current_head, &previous_commit, &root, error))
goto out;
if (!import_directory_meta (self, base, &root_metadata, &root_meta_checksum, error))
goto out;
@ -1382,21 +1504,18 @@ ostree_repo_commit (OstreeRepo *self,
if (!add_files_to_tree_and_import (self, base, modified_files, root->tree_data, error))
goto out;
if (!commit_parsed_tree (self, subject, body, metadata, root,
if (!commit_parsed_tree (self, branch, current_head,
subject, body, metadata, root,
&ret_commit_checksum, error))
goto out;
ret = TRUE;
*out_commit = ret_commit_checksum;
ret_commit_checksum = NULL;
out:
if (!ret)
{
if (ret_commit_checksum)
g_checksum_free (ret_commit_checksum);
}
else
{
*out_commit = ret_commit_checksum;
}
g_free (current_head);
if (previous_commit)
g_variant_unref (previous_commit);
parsed_directory_data_free (root);
@ -1409,6 +1528,7 @@ ostree_repo_commit (OstreeRepo *self,
gboolean
ostree_repo_commit_from_filelist_fd (OstreeRepo *self,
const char *branch,
const char *subject,
const char *body,
GVariant *metadata,
@ -1429,14 +1549,21 @@ ostree_repo_commit_from_filelist_fd (OstreeRepo *self,
GError *temp_error = NULL;
GVariant *root_metadata = NULL;
GChecksum *root_meta_checksum = NULL;
char *current_head = NULL;
g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
g_return_val_if_fail (priv->inited, FALSE);
if (branch == NULL)
branch = "master";
/* We're overwriting the tree */
if (!import_root (self, base, &root, error))
goto out;
if (!resolve_rev (self, branch, TRUE, &current_head, error))
goto out;
in = (GUnixInputStream*)g_unix_input_stream_new (fd, FALSE);
datain = g_data_input_stream_new ((GInputStream*)in);
@ -1461,21 +1588,17 @@ ostree_repo_commit_from_filelist_fd (OstreeRepo *self,
g_propagate_prefixed_error (error, temp_error, "%s", "While reading filelist: ");
goto out;
}
if (!commit_parsed_tree (self, subject, body, metadata,
if (!commit_parsed_tree (self, branch, current_head, subject, body, metadata,
root, &ret_commit_checksum, error))
goto out;
ret = TRUE;
*out_commit = ret_commit_checksum;
ret_commit_checksum = NULL;
out:
if (!ret)
{
if (ret_commit_checksum)
g_checksum_free (ret_commit_checksum);
}
else
{
*out_commit = ret_commit_checksum;
}
g_free (current_head);
if (root_metadata)
g_variant_unref (root_metadata);
if (root_meta_checksum)
@ -1640,37 +1763,6 @@ ostree_repo_load_variant (OstreeRepo *repo,
return ret;
}
const char *
ostree_repo_get_head (OstreeRepo *self)
{
OstreeRepoPrivate *priv = GET_PRIVATE (self);
g_return_val_if_fail (priv->inited, NULL);
return priv->current_head;
}
static gboolean
resolve_ref (OstreeRepo *self,
const char *ref,
char **resolved,
GError **error)
{
if (strcmp (ref, "HEAD") == 0)
{
*resolved = g_strdup (ostree_repo_get_head (self));
return TRUE;
}
else if (strlen (ref) == 64)
{
*resolved = g_strdup (ref);
return TRUE;
}
g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
"Invalid ref '%s' (must be SHA256 or HEAD)", ref);
return FALSE;
}
static gboolean
checkout_tree (OstreeRepo *self,
ParsedTreeData *tree,
@ -1762,7 +1854,7 @@ checkout_tree (OstreeRepo *self,
gboolean
ostree_repo_checkout (OstreeRepo *self,
const char *ref,
const char *rev,
const char *destination,
GError **error)
{
@ -1780,7 +1872,7 @@ ostree_repo_checkout (OstreeRepo *self,
goto out;
}
if (!resolve_ref (self, ref, &resolved, error))
if (!resolve_rev (self, rev, FALSE, &resolved, error))
goto out;
if (!load_commit_and_trees (self, resolved, &commit, &root, error))

View File

@ -59,7 +59,10 @@ gboolean ostree_repo_link_file (OstreeRepo *self,
gboolean force,
GError **error);
const char * ostree_repo_get_head (OstreeRepo *self);
gboolean ostree_repo_resolve_rev (OstreeRepo *self,
const char *rev,
char **out_resolved,
GError **error);
gboolean ostree_repo_load_variant (OstreeRepo *self,
const char *sha256,
@ -68,6 +71,7 @@ gboolean ostree_repo_load_variant (OstreeRepo *self,
GError **error);
gboolean ostree_repo_commit (OstreeRepo *self,
const char *branch,
const char *subject,
const char *body,
GVariant *metadata,
@ -78,6 +82,7 @@ gboolean ostree_repo_commit (OstreeRepo *self,
GError **error);
gboolean ostree_repo_commit_from_filelist_fd (OstreeRepo *self,
const char *branch,
const char *subject,
const char *body,
GVariant *metadata,

View File

@ -62,21 +62,56 @@ char *
ot_util_get_file_contents_utf8 (const char *path,
GError **error)
{
char *contents;
gsize len;
if (!g_file_get_contents (path, &contents, &len, error))
return NULL;
if (!g_utf8_validate (contents, len, NULL))
GFile *file = NULL;
char *ret = NULL;
file = ot_util_new_file_for_path (path);
if (!ot_util_gfile_load_contents_utf8 (file, NULL, &ret, NULL, error))
goto out;
out:
g_clear_object (&file);
return ret;
}
gboolean
ot_util_gfile_load_contents_utf8 (GFile *file,
GCancellable *cancellable,
char **contents_out,
char **etag_out,
GError **error)
{
char *ret_contents = NULL;
char *ret_etag = NULL;
gsize len;
gboolean ret = FALSE;
if (!g_file_load_contents (file, cancellable, &ret_contents, &len, &ret_etag, error))
goto out;
if (!g_utf8_validate (ret_contents, len, NULL))
{
g_free (contents);
g_set_error (error,
G_IO_ERROR,
G_IO_ERROR_FAILED,
"File %s contains invalid UTF-8",
path);
return NULL;
G_IO_ERROR_INVALID_DATA,
"Invalid UTF-8");
goto out;
}
return contents;
if (contents_out)
*contents_out = ret_contents;
else
g_free (ret_contents);
ret_contents = NULL;
if (etag_out)
*etag_out = ret_etag;
else
g_free (ret_etag);
ret_etag = NULL;
ret = TRUE;
out:
g_free (ret_contents);
g_free (ret_etag);
return ret;
}
GInputStream *

View File

@ -32,6 +32,12 @@ gboolean ot_util_ensure_directory (const char *path, gboolean with_parents, GErr
char * ot_util_get_file_contents_utf8 (const char *path, GError **error);
gboolean ot_util_gfile_load_contents_utf8 (GFile *file,
GCancellable *cancellable,
char **contents_out,
char **etag_out,
GError **error);
GInputStream *ot_util_read_file_noatime (GFile *file, GCancellable *cancellable, GError **error);
G_END_DECLS

View File

@ -33,13 +33,15 @@ static gboolean from_stdin;
static char *from_file;
static char *subject;
static char *body;
static char *branch;
static char **additions;
static char **removals;
static GOptionEntry options[] = {
{ "repo", 0, 0, G_OPTION_ARG_FILENAME, &repo_path, "Repository path", "repo" },
{ "subject", 's', 0, G_OPTION_ARG_STRING, &subject, "One line subject", "subject" },
{ "body", 'b', 0, G_OPTION_ARG_STRING, &body, "Full description", "body" },
{ "body", 'm', 0, G_OPTION_ARG_STRING, &body, "Full description", "body" },
{ "branch", 'b', 0, G_OPTION_ARG_STRING, &branch, "Branch", "branch" },
{ "from-fd", 0, 0, G_OPTION_ARG_INT, &from_fd, "Read new tree files from fd", "file descriptor" },
{ "from-stdin", 0, 0, G_OPTION_ARG_NONE, &from_stdin, "Read new tree files from stdin", "file descriptor" },
{ "from-file", 0, 0, G_OPTION_ARG_FILENAME, &from_file, "Read new tree files from another file", "path" },
@ -113,7 +115,7 @@ ostree_builtin_commit (int argc, char **argv, const char *prefix, GError **error
for (iter = removals; *iter; iter++)
g_ptr_array_add (removals_array, *iter);
if (!ostree_repo_commit (repo, subject, body, NULL,
if (!ostree_repo_commit (repo, branch, subject, body, NULL,
prefix, additions_array,
removals_array,
&commit_checksum,
@ -137,7 +139,7 @@ ostree_builtin_commit (int argc, char **argv, const char *prefix, GError **error
}
from_fd = temp_fd;
}
if (!ostree_repo_commit_from_filelist_fd (repo, subject, body, NULL,
if (!ostree_repo_commit_from_filelist_fd (repo, branch, subject, body, NULL,
prefix, from_fd, separator,
&commit_checksum, error))
{

View File

@ -121,13 +121,6 @@ ostree_builtin_fsck (int argc, char **argv, const char *prefix, GError **error)
if (!ostree_repo_iter_objects (repo, object_iter_callback, &data, error))
goto out;
head = ostree_repo_get_head (repo);
if (!head)
{
if (!quiet)
g_printerr ("No HEAD file\n");
}
if (!quiet)
g_printerr ("Total Objects: %u\n", data.n_objects);

View File

@ -41,7 +41,8 @@ ostree_builtin_log (int argc, char **argv, const char *prefix, GError **error)
OstreeRepo *repo = NULL;
GOutputStream *pager = NULL;
GVariant *commit = NULL;
char *head;
const char *rev = "master";
char *resolved_rev;
context = g_option_context_new ("- Show revision log");
g_option_context_add_main_entries (context, options, NULL);
@ -54,20 +55,19 @@ ostree_builtin_log (int argc, char **argv, const char *prefix, GError **error)
if (prefix == NULL)
prefix = ".";
if (argc > 1)
rev = argv[1];
repo = ostree_repo_new (repo_path);
if (!ostree_repo_check (repo, error))
goto out;
head = g_strdup (ostree_repo_get_head (repo));
if (!head)
{
g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED, "No HEAD exists");
goto out;
}
if (!ot_util_spawn_pager (&pager, error))
goto out;
if (!ostree_repo_resolve_rev (repo, rev, &resolved_rev, error))
goto out;
while (TRUE)
{
OstreeSerializedVariantType type;
@ -88,7 +88,7 @@ ostree_builtin_log (int argc, char **argv, const char *prefix, GError **error)
if (commit)
g_variant_unref (commit);
if (!ostree_repo_load_variant (repo, head, &type, &commit, error))
if (!ostree_repo_load_variant (repo, resolved_rev, &type, &commit, error))
goto out;
/* Ignore commit metadata for now */
@ -103,7 +103,7 @@ ostree_builtin_log (int argc, char **argv, const char *prefix, GError **error)
formatted_metadata = g_variant_print (commit_metadata, TRUE);
g_variant_unref (commit_metadata);
formatted = g_strdup_printf ("commit %s\nSubject: %s\nDate: %s\nMetadata: %s\n\n",
head, subject, formatted_date, formatted_metadata);
resolved_rev, subject, formatted_date, formatted_metadata);
g_free (formatted_metadata);
g_free (formatted_date);
formatted_date = NULL;
@ -134,8 +134,8 @@ ostree_builtin_log (int argc, char **argv, const char *prefix, GError **error)
if (strcmp (parent, "") == 0)
break;
g_free (head);
head = g_strdup (parent);
g_free (resolved_rev);
resolved_rev = g_strdup (parent);
}
if (!g_output_stream_close (pager, NULL, error))
@ -143,6 +143,7 @@ ostree_builtin_log (int argc, char **argv, const char *prefix, GError **error)
ret = TRUE;
out:
g_free (resolved_rev);
if (context)
g_option_context_free (context);
if (commit)

View File

@ -39,7 +39,8 @@ ostree_builtin_show (int argc, char **argv, const char *prefix, GError **error)
GOptionContext *context;
gboolean ret = FALSE;
OstreeRepo *repo = NULL;
const char *target;
const char *rev = "master";
char *resolved_rev = NULL;
OstreeSerializedVariantType type;
GVariant *variant = NULL;
char *formatted_variant = NULL;
@ -57,28 +58,22 @@ ostree_builtin_show (int argc, char **argv, const char *prefix, GError **error)
if (!ostree_repo_check (repo, error))
goto out;
if (argc < 2)
{
target = ostree_repo_get_head (repo);
if (!target)
{
g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED,
"No arguments specified and no HEAD exists");
goto out;
}
}
else
target = argv[1];
if (argc > 1)
rev = argv[1];
if (!ostree_repo_load_variant (repo, target, &type, &variant, error))
if (!ostree_repo_resolve_rev (repo, rev, &resolved_rev, error))
goto out;
g_print ("Object: %s\nType: %d\n", target, type);
if (!ostree_repo_load_variant (repo, resolved_rev, &type, &variant, error))
goto out;
g_print ("Object: %s\nType: %d\n", resolved_rev, type);
formatted_variant = g_variant_print (variant, TRUE);
g_print ("%s\n", formatted_variant);
ret = TRUE;
out:
g_free (resolved_rev);
if (context)
g_option_context_free (context);
g_clear_object (&repo);

View File

@ -25,7 +25,7 @@ cd "$test_tmpdir"
touch "$test_tmpdir/.test$$"
die () {
if test -z "$HT_TESTS_SAVE_TEMPS"; then
if test -z "$OT_TESTS_SAVE_TEMPS"; then
test -f "$test_tmpdir/.test$$" && rm -rf "$test_tmpdir"
else
echo "Temporary files saved in $test_tmpdir"
@ -60,8 +60,8 @@ setup_test_repository1 () {
ot_repo="--repo=../repo"
export ot_repo
ostree init $ot_repo
ostree commit $ot_repo -s "Test Commit 1" -b "Commit body first" --add=firstfile
ostree commit $ot_repo -s "Test Commit 2" -b "Commit body second" --add=secondfile
ostree commit $ot_repo -s "Test Commit 1" -m "Commit body first" --add=firstfile
ostree commit $ot_repo -s "Test Commit 2" -m "Commit body second" --add=secondfile
ostree fsck -q $ot_repo
}
@ -86,8 +86,8 @@ setup_test_repository2 () {
cd ../files
export ot_repo
ostree init $ot_repo
ostree commit $ot_repo -s "Test Commit 1" -b "Commit body first" --add=firstfile
ostree commit $ot_repo -s "Test Commit 2" -b "Commit body second" --add=baz/cow --add=baz/saucer --add=baz/deeper/ohyeah --add=baz/another/y
ostree commit $ot_repo -s "Test Commit 1" -m "Commit body first" --add=firstfile
ostree commit $ot_repo -s "Test Commit 2" -m "Commit body second" --add=baz/cow --add=baz/saucer --add=baz/deeper/ohyeah --add=baz/another/y
ostree fsck -q $ot_repo
}

View File

@ -32,7 +32,7 @@ mkdir ../repo
repo="--repo=../repo"
ostree init $repo
echo 'ok init'
ostree commit $repo -s "Test Commit" -b "Commit body" --add=yy
ostree commit $repo -s "Test Commit" -m "Commit body" --add=yy
echo 'ok commit'
ostree fsck -q $repo
echo 'ok fsck'

View File

@ -33,9 +33,9 @@ mkdir ../repo
repo="--repo=../repo"
ostree init $repo
echo 'ok init'
ostree commit $repo -s "Test Commit 1" -b "Commit body first" --add=firstfile
ostree commit $repo -s "Test Commit 1" -m "Commit body first" --add=firstfile
echo 'ok commit 1'
ostree commit $repo -s "Test Commit 2" -b "Commit body first" --add=secondfile
ostree commit $repo -s "Test Commit 2" -m "Commit body first" --add=secondfile
echo 'ok commit 2'
ostree fsck -q $repo
echo 'ok fsck'

View File

@ -26,7 +26,7 @@ echo '1..3'
setup_test_repository1
echo 'ok setup'
ostree checkout $ot_repo HEAD $test_tmpdir/checkout1-head
ostree checkout $ot_repo master $test_tmpdir/checkout1-head
echo 'ok checkout cmd'
cd $test_tmpdir/checkout1-head
assert_has_file firstfile

View File

@ -26,7 +26,7 @@ echo '1..5'
setup_test_repository2
echo 'ok setup'
ostree checkout $ot_repo HEAD $test_tmpdir/checkout2-head
ostree checkout $ot_repo master $test_tmpdir/checkout2-head
echo 'ok checkout cmd'
cd $test_tmpdir/checkout2-head
assert_has_file firstfile

View File

@ -25,14 +25,14 @@ set -e
echo '1..4'
setup_test_repository2
ostree checkout $ot_repo HEAD $test_tmpdir/checkout2-head
ostree checkout $ot_repo master $test_tmpdir/checkout2-head
echo 'ok setup'
cd $test_tmpdir/checkout2-head
ostree commit -s delete $ot_repo -r firstfile
echo 'ok rm firstfile'
assert_has_file firstfile # It should still exist in this checkout
cd $test_tmpdir
ostree checkout $ot_repo HEAD $test_tmpdir/checkout3-head
ostree checkout $ot_repo master $test_tmpdir/checkout3-head
echo 'ok checkout 3'
cd $test_tmpdir/checkout3-head
assert_not_has_file firstfile

View File

@ -25,7 +25,7 @@ set -e
echo "1..2"
setup_test_repository2
ostree checkout $ot_repo HEAD $test_tmpdir/checkout2-head
ostree checkout $ot_repo master $test_tmpdir/checkout2-head
cd $test_tmpdir/checkout2-head
mkdir -p a/nested/tree
echo one > a/nested/tree/1
@ -41,7 +41,7 @@ echo whee2 > another/whee
# FIXME - remove grep for .
find | grep -v '^\.$' | ostree commit $ot_repo --from-stdin -s "From find"
echo "ok commit stdin"
ostree checkout $ot_repo HEAD $test_tmpdir/checkout3-head
ostree checkout $ot_repo master $test_tmpdir/checkout3-head
cd $test_tmpdir/checkout3-head
assert_has_file a/nested/2
assert_file_has_content a/nested/2 'two2'

View File

@ -26,10 +26,10 @@ echo "1..2"
setup_test_repository2
ostree checkout $ot_repo HEAD $test_tmpdir/checkout2-head
ostree checkout $ot_repo master $test_tmpdir/checkout2-head
cd $ht_files
ln -s foo bar
ostree commit $ot_repo -s "Add a symlink" -b "To test it" --add=bar
ostree commit $ot_repo -s "Add a symlink" -m "To test it" --add=bar
echo "ok commit symlink"
ostree fsck $ot_repo
echo "ok fsck"