Beispiel #1
0
        public void AddBooking(string guest, int room, DateTime date)
        {
            if (!IsRoomAvailable(room, date))
            {
                //I did this instead of throwing an exception so the other tests could run
                Console.WriteLine("Room isn't available on that date.");
            }

            using (var db = new HotelBookingsDBContext())
            {
                var id = db.Rooms.Where(r => r.RoomId == room).Select(r => r.Id).FirstOrDefault();

                var bookedRoom = new BookedRoom
                {
                    RoomId      = id,
                    BookingDate = date.ToShortDateString(),
                    GuestName   = guest
                };;

                lock (bookingsLock)
                {
                    db.BookedRooms.Add(bookedRoom);
                    db.SaveChanges();
                }
            }
        }
Beispiel #2
0
        public IEnumerable <int> GetAvailableRooms(DateTime date)
        {
            using (var db = new HotelBookingsDBContext())
            {
                var dateString = date.ToShortDateString();

                var bookedRooms = db.BookedRooms
                                  .Where(b => b.BookingDate == dateString)
                                  .Select(b => b.RoomId);

                var roomIds    = db.Rooms.Select(r => r.Id).ToList();
                var availRooms = new List <int>();

                foreach (var room in bookedRooms)
                {
                    if (roomIds.Contains(room))
                    {
                        roomIds.Remove(room);
                    }
                }

                foreach (var roomId in roomIds)
                {
                    availRooms.Add(db.Rooms.Where(r => r.Id == roomId).Select(r => r.RoomId).FirstOrDefault());
                }

                return(availRooms);
            }
        }
Beispiel #3
0
        public bool IsRoomAvailable(int room, DateTime date)
        {
            using (var db = new HotelBookingsDBContext())
            {
                var dateString = date.ToShortDateString();
                var isBooked   = db.BookedRooms.Any(b => b.Room.RoomId == room && b.BookingDate == dateString);

                return(!isBooked);
            }
        }