blob: 32f49b21498d5030ada37b22b179a3473d3ecf78 [file] [log] [blame]
license.botbf09a502008-08-24 00:55:551// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
initial.commitd7cae122008-07-26 21:49:384
[email protected]640517f2008-10-30 23:54:045#include "base/path_service.h"
6
initial.commitd7cae122008-07-26 21:49:387#include "base/basictypes.h"
8#include "base/file_util.h"
[email protected]640517f2008-10-30 23:54:049#include "base/file_path.h"
[email protected]6723f832008-08-11 15:38:2710#if defined(OS_WIN)
[email protected]09ad1e622008-08-07 20:23:0911#include "base/win_util.h"
[email protected]6723f832008-08-11 15:38:2712#endif
initial.commitd7cae122008-07-26 21:49:3813#include "testing/gtest/include/gtest/gtest.h"
[email protected]09ad1e622008-08-07 20:23:0914#include "testing/gtest/include/gtest/gtest-spi.h"
[email protected]23887f04f2008-12-02 19:20:1515#include "testing/platform_test.h"
initial.commitd7cae122008-07-26 21:49:3816
17namespace {
initial.commitd7cae122008-07-26 21:49:3818
19// Returns true if PathService::Get returns true and sets the path parameter
20// to non-empty for the given PathService::DirType enumeration value.
21bool ReturnsValidPath(int dir_type) {
[email protected]640517f2008-10-30 23:54:0422 FilePath path;
initial.commitd7cae122008-07-26 21:49:3823 bool result = PathService::Get(dir_type, &path);
[email protected]640517f2008-10-30 23:54:0424 return result && !path.value().empty() && file_util::PathExists(path);
initial.commitd7cae122008-07-26 21:49:3825}
26
[email protected]6723f832008-08-11 15:38:2727#if defined(OS_WIN)
[email protected]09ad1e622008-08-07 20:23:0928// Function to test DIR_LOCAL_APP_DATA_LOW on Windows XP. Make sure it fails.
[email protected]0cfda1e2008-08-07 23:59:0429bool ReturnsInvalidPath(int dir_type) {
[email protected]b65de8b92009-09-14 19:36:3130 FilePath path;
[email protected]09ad1e622008-08-07 20:23:0931 bool result = PathService::Get(base::DIR_LOCAL_APP_DATA_LOW, &path);
[email protected]0cfda1e2008-08-07 23:59:0432 return !result && path.empty();
[email protected]09ad1e622008-08-07 20:23:0933}
[email protected]6723f832008-08-11 15:38:2734#endif
[email protected]09ad1e622008-08-07 20:23:0935
36} // namespace
37
[email protected]ed2f2332008-08-20 15:59:4938// On the Mac this winds up using some autoreleased objects, so we need to
39// be a PlatformTest.
40typedef PlatformTest PathServiceTest;
41
initial.commitd7cae122008-07-26 21:49:3842// Test that all PathService::Get calls return a value and a true result
43// in the development environment. (This test was created because a few
44// later changes to Get broke the semantics of the function and yielded the
45// correct value while returning false.)
[email protected]ed2f2332008-08-20 15:59:4946TEST_F(PathServiceTest, Get) {
initial.commitd7cae122008-07-26 21:49:3847 for (int key = base::DIR_CURRENT; key < base::PATH_END; ++key) {
48 EXPECT_PRED1(ReturnsValidPath, key);
49 }
[email protected]1010f7d2008-08-06 16:29:4450#ifdef OS_WIN
51 for (int key = base::PATH_WIN_START + 1; key < base::PATH_WIN_END; ++key) {
[email protected]09ad1e622008-08-07 20:23:0952 if (key == base::DIR_LOCAL_APP_DATA_LOW &&
53 win_util::GetWinVersion() < win_util::WINVERSION_VISTA) {
54 // DIR_LOCAL_APP_DATA_LOW is not supported prior Vista and is expected to
55 // fail.
[email protected]0cfda1e2008-08-07 23:59:0456 EXPECT_TRUE(ReturnsInvalidPath(key)) << key;
[email protected]09ad1e622008-08-07 20:23:0957 } else {
[email protected]0cfda1e2008-08-07 23:59:0458 EXPECT_TRUE(ReturnsValidPath(key)) << key;
[email protected]09ad1e622008-08-07 20:23:0959 }
[email protected]1010f7d2008-08-06 16:29:4460 }
61#endif
initial.commitd7cae122008-07-26 21:49:3862}