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. 20GTEST_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. 24GMOCK_DIR = .. 25 26# Where to find user code. 27USER_DIR = ../test 28 29# Flags passed to the preprocessor. 30CPPFLAGS += -I$(GTEST_DIR)/include -I$(GMOCK_DIR)/include 31 32# Flags passed to the C++ compiler. 33CXXFLAGS += -g -Wall -Wextra 34 35# All tests produced by this Makefile. Remember to add new tests you 36# created to the list. 37TESTS = gmock_test 38 39# All Google Test headers. Usually you shouldn't change this 40# definition. 41GTEST_HEADERS = $(GTEST_DIR)/include/gtest/*.h \ 42 $(GTEST_DIR)/include/gtest/internal/*.h 43 44# All Google Mock headers. Note that all Google Test headers are 45# included here too, as they are #included by Google Mock headers. 46# Usually you shouldn't change this definition. 47GMOCK_HEADERS = $(GMOCK_DIR)/include/gmock/*.h \ 48 $(GMOCK_DIR)/include/gmock/internal/*.h \ 49 $(GTEST_HEADERS) 50 51# House-keeping build targets. 52 53all : $(TESTS) 54 55clean : 56 rm -f $(TESTS) gmock.a gmock_main.a *.o 57 58# Builds gmock.a and gmock_main.a. These libraries contain both 59# Google Mock and Google Test. A test should link with either gmock.a 60# or gmock_main.a, depending on whether it defines its own main() 61# function. It's fine if your test only uses features from Google 62# Test (and not Google Mock). 63 64# Usually you shouldn't tweak such internal variables, indicated by a 65# trailing _. 66GTEST_SRCS_ = $(GTEST_DIR)/src/*.cc $(GTEST_DIR)/src/*.h $(GTEST_HEADERS) 67GMOCK_SRCS_ = $(GMOCK_DIR)/src/*.cc $(GMOCK_HEADERS) 68 69# For simplicity and to avoid depending on implementation details of 70# Google Mock and Google Test, the dependencies specified below are 71# conservative and not optimized. This is fine as Google Mock and 72# Google Test compile fast and for ordinary users their source rarely 73# changes. 74gtest-all.o : $(GTEST_SRCS_) 75 $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \ 76 -c $(GTEST_DIR)/src/gtest-all.cc 77 78gmock-all.o : $(GMOCK_SRCS_) 79 $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \ 80 -c $(GMOCK_DIR)/src/gmock-all.cc 81 82gmock_main.o : $(GMOCK_SRCS_) 83 $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) -I$(GMOCK_DIR) $(CXXFLAGS) \ 84 -c $(GMOCK_DIR)/src/gmock_main.cc 85 86gmock.a : gmock-all.o gtest-all.o 87 $(AR) $(ARFLAGS) $@ $^ 88 89gmock_main.a : gmock-all.o gtest-all.o gmock_main.o 90 $(AR) $(ARFLAGS) $@ $^ 91 92# Builds a sample test. 93 94gmock_test.o : $(USER_DIR)/gmock_test.cc $(GMOCK_HEADERS) 95 $(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(USER_DIR)/gmock_test.cc 96 97gmock_test : gmock_test.o gmock_main.a 98 $(CXX) $(CPPFLAGS) $(CXXFLAGS) -lpthread $^ -o $@ 99