Upstream version 9.38.198.0
[platform/framework/web/crosswalk.git] / src / testing / gmock / make / Makefile
1 # A sample Makefile for building both Google Mock and Google Test and
2 # using them in user tests.  This file is self-contained, so you don't
3 # need to use the Makefile in Google Test's source tree.  Please tweak
4 # it to suit your environment and project.  You may want to move it to
5 # your project's root directory.
6 #
7 # SYNOPSIS:
8 #
9 #   make [all]  - makes everything.
10 #   make TARGET - makes the given target.
11 #   make clean  - removes all files generated by make.
12
13 # Please tweak the following variable definitions as needed by your
14 # project, except GMOCK_HEADERS and GTEST_HEADERS, which you can use
15 # in your own targets but shouldn't modify.
16
17 # Points to the root of Google Test, relative to where this file is.
18 # Remember to tweak this if you move this file, or if you want to use
19 # a copy of Google Test at a different location.
20 GTEST_DIR = ../gtest
21
22 # Points to the root of Google Mock, relative to where this file is.
23 # Remember to tweak this if you move this file.
24 GMOCK_DIR = ..
25
26 # Where to find user code.
27 USER_DIR = ../test
28
29 # Flags passed to the preprocessor.
30 # Set Google Test and Google Mock's header directories as system
31 # directories, such that the compiler doesn't generate warnings in
32 # these headers.
33 CPPFLAGS += -isystem $(GTEST_DIR)/include -isystem $(GMOCK_DIR)/include
34
35 # Flags passed to the C++ compiler.
36 CXXFLAGS += -g -Wall -Wextra -pthread
37
38 # All tests produced by this Makefile.  Remember to add new tests you
39 # created to the list.
40 TESTS = gmock_test
41
42 # All Google Test headers.  Usually you shouldn't change this
43 # definition.
44 GTEST_HEADERS = $(GTEST_DIR)/include/gtest/*.h \
45                 $(GTEST_DIR)/include/gtest/internal/*.h
46
47 # All Google Mock headers. Note that all Google Test headers are
48 # included here too, as they are #included by Google Mock headers.
49 # Usually you shouldn't change this definition. 
50 GMOCK_HEADERS = $(GMOCK_DIR)/include/gmock/*.h \
51                 $(GMOCK_DIR)/include/gmock/internal/*.h \
52                 $(GTEST_HEADERS)
53
54 # House-keeping build targets.
55
56 all : $(TESTS)
57
58 clean :
59         rm -f $(TESTS) gmock.a gmock_main.a *.o
60
61 # Builds gmock.a and gmock_main.a.  These libraries contain both
62 # Google Mock and Google Test.  A test should link with either gmock.a
63 # or gmock_main.a, depending on whether it defines its own main()
64 # function.  It's fine if your test only uses features from Google
65 # Test (and not Google Mock).
66
67 # Usually you shouldn't tweak such internal variables, indicated by a
68 # trailing _.
69 GTEST_SRCS_ = $(GTEST_DIR)/src/*.cc $(GTEST_DIR)/src/*.h $(GTEST_HEADERS)
70 GMOCK_SRCS_ = $(GMOCK_DIR)/src/*.cc $(GMOCK_HEADERS)
71
72 # For simplicity and to avoid depending on implementation details of
73 # Google Mock and Google Test, the dependencies specified below are
74 # conservative and not optimized.  This is fine as Google Mock and
75 # Google Test compile fast and for ordinary users their source rarely
76 # changes.
77 gtest-all.o : $(GTEST_SRCS_)
78         $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \
79             -c $(GTEST_DIR)/src/gtest-all.cc
80
81 gmock-all.o : $(GMOCK_SRCS_)
82         $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \
83             -c $(GMOCK_DIR)/src/gmock-all.cc
84
85 gmock_main.o : $(GMOCK_SRCS_)
86         $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \
87             -c $(GMOCK_DIR)/src/gmock_main.cc
88
89 gmock.a : gmock-all.o gtest-all.o
90         $(AR) $(ARFLAGS) $@ $^
91
92 gmock_main.a : gmock-all.o gtest-all.o gmock_main.o
93         $(AR) $(ARFLAGS) $@ $^
94
95 # Builds a sample test.
96
97 gmock_test.o : $(USER_DIR)/gmock_test.cc $(GMOCK_HEADERS)
98         $(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(USER_DIR)/gmock_test.cc
99
100 gmock_test : gmock_test.o gmock_main.a
101         $(CXX) $(CPPFLAGS) $(CXXFLAGS) -lpthread $^ -o $@