• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

realm / realm-core / 2032

13 Feb 2024 12:49PM UTC coverage: 91.866% (+0.02%) from 91.844%
2032

push

Evergreen

web-flow
Add RealmConfig::needs_file_format_upgrade (#7336)

93052 of 171506 branches covered (54.26%)

36 of 45 new or added lines in 6 files covered. (80.0%)

79 existing lines in 15 files now uncovered.

235424 of 256268 relevant lines covered (91.87%)

6438906.58 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

90.0
/src/realm/sync/noinst/client_reset_operation.cpp
1
/*************************************************************************
2
 *
3
 * Copyright 2021 Realm Inc.
4
 *
5
 * Licensed under the Apache License, Version 2.0 (the "License");
6
 * you may not use this file except in compliance with the License.
7
 * You may obtain a copy of the License at
8
 *
9
 * http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 *
17
 **************************************************************************/
18

19
#include <realm/sync/noinst/client_reset_operation.hpp>
20

21
#include <realm/sync/history.hpp>
22
#include <realm/sync/noinst/client_history_impl.hpp>
23
#include <realm/sync/noinst/client_reset.hpp>
24
#include <realm/transaction.hpp>
25
#include <realm/util/scope_exit.hpp>
26

27
namespace realm::_impl::client_reset {
28

29
namespace {
30

31
constexpr static std::string_view c_fresh_suffix(".fresh");
32

33
} // namespace
34

35
std::string get_fresh_path_for(const std::string& path)
36
{
55,332✔
37
    const size_t suffix_len = c_fresh_suffix.size();
55,332✔
38
    REALM_ASSERT(path.length());
55,332✔
39
    REALM_ASSERT_DEBUG_EX(
55,332✔
40
        path.size() < suffix_len || path.substr(path.size() - suffix_len, suffix_len) != c_fresh_suffix, path);
55,332✔
41
    return path + c_fresh_suffix.data();
55,332✔
42
}
55,332✔
43

44
bool is_fresh_path(const std::string& path)
45
{
3,772✔
46
    const size_t suffix_len = c_fresh_suffix.size();
3,772✔
47
    REALM_ASSERT(path.length());
3,772✔
48
    if (path.size() < suffix_len) {
3,772✔
49
        return false;
×
50
    }
×
51
    return path.substr(path.size() - suffix_len, suffix_len) == c_fresh_suffix;
3,772✔
52
}
3,772✔
53

54
bool perform_client_reset(util::Logger& logger, DB& db, DB& fresh_db, ClientResyncMode mode,
55
                          CallbackBeforeType notify_before, CallbackAfterType notify_after,
56
                          sync::SaltedFileIdent new_file_ident, sync::SubscriptionStore* sub_store,
57
                          util::FunctionRef<void(int64_t)> on_flx_version, bool recovery_is_allowed)
58
{
460✔
59
    REALM_ASSERT(mode != ClientResyncMode::Manual);
460✔
60
    logger.debug("Possibly beginning client reset operation: realm_path = %1, mode = %2, recovery_allowed = %3",
460✔
61
                 db.get_path(), mode, recovery_is_allowed);
460✔
62

230✔
63
    auto always_try_clean_up = util::make_scope_exit([&]() noexcept {
460✔
64
        std::string path_to_clean = fresh_db.get_path();
460✔
65
        try {
460✔
66
            fresh_db.close();
460✔
67
            constexpr bool delete_lockfile = true;
460✔
68
            DB::delete_files(path_to_clean, nullptr, delete_lockfile);
460✔
69
        }
460✔
70
        catch (const std::exception& err) {
230✔
UNCOV
71
            logger.warn("In ClientResetOperation::finalize, the fresh copy '%1' could not be cleaned up due to "
×
UNCOV
72
                        "an exception: '%2'",
×
UNCOV
73
                        path_to_clean, err.what());
×
74
            // ignored, this is just a best effort
UNCOV
75
        }
×
76
    });
460✔
77

230✔
78
    // only do the reset if there is data to reset
230✔
79
    // if there is nothing in this Realm, then there is nothing to reset and
230✔
80
    // sync should be able to continue as normal
230✔
81
    auto latest_version = db.get_version_id_of_latest_snapshot();
460✔
82
    bool local_realm_exists = latest_version.version > 1;
460✔
83
    if (!local_realm_exists) {
460✔
84
        logger.debug("Local Realm file has never been written to, so skipping client reset.");
4✔
85
        return false;
4✔
86
    }
4✔
87

228✔
88
    VersionID frozen_before_state_version = notify_before ? notify_before() : latest_version;
456✔
89

228✔
90
    // If m_notify_after is set, pin the previous state to keep it around.
228✔
91
    TransactionRef previous_state;
456✔
92
    if (notify_after) {
456✔
93
        previous_state = db.start_frozen(frozen_before_state_version);
260✔
94
    }
260✔
95
    bool did_recover = client_reset::perform_client_reset_diff(
456✔
96
        db, fresh_db, new_file_ident, logger, mode, recovery_is_allowed, sub_store, on_flx_version); // throws
456✔
97

228✔
98
    if (notify_after) {
456✔
99
        notify_after(previous_state->get_version_of_current_transaction(), did_recover);
200✔
100
    }
200✔
101

228✔
102
    return true;
456✔
103
}
456✔
104

105
} // namespace realm::_impl::client_reset
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc