Пример #1
0
        public async Task <IActionResult> PutItem(string id, Item item)
        {
            if (id != item.Sku)
            {
                return(BadRequest());
            }

            _context.Entry(item).State = EntityState.Modified;

            try
            {
                await _context.SaveChangesAsync();
            }
            catch (DbUpdateConcurrencyException)
            {
                if (!ItemExists(id))
                {
                    return(NotFound());
                }
                else
                {
                    throw;
                }
            }

            return(NoContent());
        }
Пример #2
0
        private async Task <WarehouseDBContext> GetDatabaseContext()
        {
            var options = new DbContextOptionsBuilder <WarehouseDBContext>()
                          .UseInMemoryDatabase(databaseName: Guid.NewGuid().ToString())
                          .Options;
            var databaseContext = new WarehouseDBContext(options);

            databaseContext.Database.EnsureCreated();
            if (await databaseContext.Order.CountAsync() <= 0)
            {
                for (int i = 1; i <= 5; i++)
                {
                    databaseContext.Order.Add(new Infrastructure.Entities.Order()
                    {
                        Id       = i,
                        Sku      = "Test" + i.ToString(),
                        Modified = DateTime.Now.AddDays(-1),
                        Status   = 1,
                        Quantity = i * 2,
                        UserId   = 1
                    });
                    await databaseContext.SaveChangesAsync();
                }
            }
            return(databaseContext);
        }
Пример #3
0
        public async Task <IActionResult> PutOrder(int id, Order order)
        {
            if (id != order.Id)
            {
                return(BadRequest());
            }

            _context.Entry(order).State = EntityState.Modified;

            var logOrder = new LogOrder()
            {
                Sku      = order.Sku,
                Modified = DateTime.Now,
                OrderId  = order.Id,
                UserId   = order.UserId,
                Quantity = order.Quantity,
                Status   = order.Status
            };

            _context.LogOrder.Add(logOrder);

            try
            {
                await _context.SaveChangesAsync();
            }
            catch (DbUpdateConcurrencyException)
            {
                if (!OrderExists(id))
                {
                    return(NotFound());
                }
                else
                {
                    throw;
                }
            }

            return(NoContent());
        }