dom/media/gtest/TestDataMutex.cpp
author Sylvestre Ledru <sledru@mozilla.com>
Thu, 04 Apr 2019 20:12:23 +0000
changeset 468068 389b6bbd76dbdf3357453f0989bbe9595751b7ae
parent 450760 09c71a7cf75aeaf2963050e315276fb9a866fd62
child 468070 9e48fefcf1aca74fd97036121180907de52756e8
permissions -rw-r--r--
Bug 1519636 - clang-format-8: Reformat recent changes to the Google coding style r=Ehsan clang-format-8 upstream had some improvements wrt macros See: https://reviews.llvm.org/D33440 This is why the diff is bigger than usual # ignore-this-changeset Differential Revision: https://phabricator.services.mozilla.com/D26098

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* 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 http://mozilla.org/MPL/2.0/. */

#include "gtest/gtest.h"
#include "mozilla/DataMutex.h"
#include "nsTArray.h"

using mozilla::DataMutex;

struct A {
  void Set(int a) { mValue = a; }
  int mValue;
};

TEST(DataMutex, Basic)
{
  {
    DataMutex<uint32_t> i(1, "1");
    auto x = i.Lock();
    *x = 4;
    ASSERT_EQ(*x, 4u);
  }
  {
    DataMutex<A> a({4}, "StructA");
    auto x = a.Lock();
    ASSERT_EQ(x->mValue, 4);
    x->Set(8);
    ASSERT_EQ(x->mValue, 8);
  }
  {
    DataMutex<nsTArray<uint32_t>> _a("array");
    auto a = _a.Lock();
    auto& x = a.ref();
    ASSERT_EQ(x.Length(), 0u);
    x.AppendElement(1u);
    ASSERT_EQ(x.Length(), 1u);
    ASSERT_EQ(x[0], 1u);
  }
}