adding 1.6.5 update site
[gae.git] / java / RELEASE_NOTES
blob743d5cf83bdf5f161ffe85e8a4f46348514c1a13
1 Copyright 2008 Google Inc.
2 All rights reserved.
4 App Engine Java SDK - Release Notes
6 Version 1.6.4
7 =============
8 - Billed applications that have specified additional logs retention over 1 GB
9   are now being charged for that storage at $0.24/GB/month (the first gigabyte
10   of logs storage is free). All logs beyond an application's specified storage
11   limit will be deleted. Please examine your Application Settings page to verify
12   you are retaining the desired amount of logs.
13 - Datastore statistics now show the amount of storage used by application
14   indexes.
15 - We have released an experimental utility for migrating your application's
16   blobs at the same time you migrate your datastore data. You can opt-in to
17   blob migration in the Admin Console when you start your migration.
18 - We have updated the experimental Backup/Restore functionality to include
19   the option to backup and restore to Google Storage for Developers.
20 - Version 2.0 of the App Engine DataNucleus plugin is now available as an
21   experimental release. This plugin contains support for JDO 3 and JPA 2 and
22   over 40 bug fixes. For a full list see:
23     http://code.google.com/p/datanucleus-appengine/source/browse/branches/2_0_0/dist/RELEASE_NOTES.ORM
24 - Threads are available as an experimental feature via
25   com.google.appengine.api.ThreadManager.
26 - The Admin Console now provides a Memcache viewer that lists Memcache stats and
27   can display Memcache content based on key.
28 - Using the blobstoreService.serve method, your application can serve objects
29   hosted on Google Cloud Storage.
30 - The method ApiProxy.getRemainingMillis() returns the amount of milliseconds
31   remaining before a request hits the request deadline.
32 - New datastore query related callbacks - PreGet(), PreQuery(), and PostLoad()
33   are now available.
34 - Omitting the <threadsafe> directive from appengine-web.xml now results in
35   a warning. Starting with the 1.6.5 release, omitting this directive will
36   result in an error.
37 - You can set an RPC deadline for the Task Queue API's leaseTasks() method.
38 - The Datastore Admin tab in the Admin Console now shows entities from every
39   namespace.
40     http://code.google.com/p/googleappengine/issues/detail?id=3962
41 - GQL queries in the Admin Console no longer throw an error when a trailing
42   semi-colon is included.
43 - Fixed an issue where setting ApiProxy delegate caused ClassCastException in
44   unit test teardown.
45     http://code.google.com/p/googleappengine/issues/detail?id=4442
46 - Fixed an issue where <async-session-persistence> did not work.
47     http://code.google.com/p/googleappengine/issues/detail?id=5774
48 - The Datastore Admin now shows entities from every namespace.
49     http://code.google.com/p/googleappengine/issues/detail?id=3962
50 - Fixed an issue in the Java Development Server where Task Queue retry
51   parameters were ignored.
52     http://code.google.com/p/googleappengine/issues/detail?id=5200
53 - Fixed an issue in the Java Pipeline API
54   (http://code.google.com/p/appengine-pipeline/) that would lead to "No object
55   found in pool with id=barrier(...)" errors when used in HRD applications.
58 Version 1.6.3
59 =============
60 - In the Admin Console, you can use the new Traffic Splitting feature to send a
61   certain percentage of traffic to a non-default application version. The
62   traffic is split by either cookie or IP address.
63 - Emails that are sent from Google Apps domains email addresses where the domain
64   has been set up to use DKIM will be signed: when an email was from a request
65   that originated on that app's domain or any time the email was sent from
66   an app adminstrator, including when that email is sent from a cron job or task
67   queue request.
68 - In the Admin Console, you can now choose how much and how long you'd like to
69   store logs.  All apps get 1G for free and eventually will be able to pay for
70   more, while the amount can be increased this release we won't start charging
71   for the additional capacity until the next release at the earliest.
72 - The instances screen in the Admin Console now has a button to shut down
73   a specific instance.
74 - Each application log has a link to the instance that served the request. If
75   the instance is no longer serving requests, a message will be displayed.
76 - The TaskQueue API now supports the ability to tag a Pull Queue task. You may
77   then lease tasks by tag. This feature is experimental.
78 - Using Google Apps wildcard domain mappings, you can access alternate
79   versions of your app via a custom domain.
80 - Push and Pull Queues are now listed separately in the SDK development console.
81 - The PermGen size for  backend and frontend instances classes has been
82   increased. The values are as follows: F1/B1 - 44MB, F2/B2 - 108MB,
83   F4/B4 - 236MB, B8 - 492.
84 - The DataNucleus Enhancer command line tool
85   (com.google.appengine.tools.enhancer.Enhance) now supports the
86   -enhancerVersion flag, which allow you to specify the version of DataNucleus
87   with which to enhance your JDO/JPA classes.
88 - The dev appserver command line now supports the --generated_dir flag, which
89   allows you to specify a directory in which to write files generated by the
90   SDK.
91 - Fixed a StackOverflowError when using the Remote API.
92     http://code.google.com/p/googleappengine/issues/detail?id=6349
94 Version 1.6.2
95 =============
96 - The Admin Console Datastore Admin has added experimental backup and restore
97   functionality. The job occurs within your application and counts against your
98   application quota, including Instance Hours, Datastore Ops and Datastore
99   Storage.
100 - Developers can now specify how long a channel token will last until it
101   expires, with the default remaining two hours. Channel API quota is now
102   measured both in calls to create a channel and the number of hours of channel
103   time requested. The maximum hours of quota is the maximum number of channel
104   creation calls * 2, so free apps get 200 hours of requested channel token
105   time.
106 - Task Queue API requests now include a X-Appengine-TaskETA header, that can be
107   used to measure task delivery latency.
108 - We have removed the deprecated labs version of the TaskQueue API.
109 - The default API deadlines for Blobstore API calls have been raised to 15s for
110   online and 30s for offline requests, up from 5s.
111 - The Images API now allows you to stretch an image without maintaining the
112   aspect ratio.
113     http://code.google.com/p/googleappengine/issues/detail?id=2220
114 - Mail Quota for App Engine apps that have signed up for billing will only be
115   increased after the first payment for the app is processed.
116 - Fixed an issue where the SDK did not resize images down to 512 pixels by
117   default, as it does in production.
118 - Fixed an issue with the Images API where valid images were returning a
119   NotImageError.
120     http://code.google.com/p/googleappengine/issues/detail?id=5545
122 Version 1.6.1
123 =============
124 - You can now configure Frontend Instance Classes from your Admin Console's
125   application settings page. Three classes are available, with increasing
126   memory, CPU limits, and associated cost. By default, all applications use the
127   basic frontend instance setting of 128MB memory and 600MHz CPU.
128 - We've added new functionality to the Log API that will allow you to read your
129   application's logs programmatically.
130 - We are releasing an experimental Conversion API that will allow you to convert
131   between document types including .doc, .html, .pdf, images using OCR, and
132   more.
133 - The High Replication Datastore migration utility is now available as a GA
134   feature, and is no longer experimental.
135 - The dev appserver now emits a warning when loading any classes that fall under
136   com.google.appengine.repackaged.*.
137 - Version 2.0.0 of the DataNucleus App Engine plugin is available as an
138   experimental download from http://goo.gl/kyQiO. This release
139   adds support for JPA2 and JDO3. Installation instructions are available at
140   http://goo.gl/ELBL4.
141 - The Blobstore API now supports the multiple="true" attribute to the HTML input
142   tag.
143 - TaskOptions.Param now implements Serializable.
144     http://code.google.com/p/googleappengine/issues/detail?id=3712
145 - Fixed an issue in the SDK where logging "null" caused a 500 error.
146 - Fixed an issue with backends where SessionManager might try to save a session
147   forever under certain circumstances.
148 - Fixed an issue where cached static files served to IPs on the DoS blacklist
149   consumed bandwidth quota.
150     http://code.google.com/p/googleappengine/issues/detail?id=4607
152 Version 1.6.0
153 =============
154 - On November 7th, App Engine will be out of Preview. The new Terms of Service
155   and previously announced pricing changes will be in effect. Additionally, all
156   paid apps are now covered by our SLA.
157     http://code.google.com/appengine/docs/billing.html
158 - Paid apps can now specify the maximum pending latency for instances and the
159   minimum number of idle instances for your application in the Admin Console.
160 - Task Queue storage has been separated in to its own line item. Previously,
161   this was included in Datastore storage.
162 - We have released an experimental utility, available in the Admin Console, to
163   assist in migrating your application to the High Replication datastore. This
164   utility allows you to copy the bulk of your data in the background, while the
165   source application is still serving. You then need a brief read-only period to
166   migrate your application data while you copy the data that has changed from
167   the time the original copy started.
168 - Blobstore, which was previously limited to apps with billing enabled, is now
169   available for all apps.
170 - We have published a new article on Datastore Index Selection and Advanced
171   Search which explains our recent improvements to the query planner that make
172   exploding indexes unnecessary.
173     http://code.google.com/appengine/articles/indexselection.html
174 - Applications can now receive xmpp error stanzas at /_ah/xmpp/error.
175 - In the Admin Console data viewer, you can now filter by namespace from a drop
176   down menu, if applicable.
177 - In the Admin Console's Datastore Statistics, we now offer namespace suggest
178   for filtering stats.
179 - Added API functionality for making calls to the Memcache API asynchronously.
180 - In the Memcache API, getIdentifiable() and putIfUntouched() now support
181   batch operations.
182 - We've added a page, /_ah/admin/capabilitiesstatus, to the dev console that
183   allows you to configure the capability state of the local API implementations
184   when running locally.
185 - We've added LocalCapabilitiesServiceTestConfig to the testing API, which
186   allows you to configure the capability state of the local API implementations
187   in your tests.
188 - The Datastore API now supports callbacks that can execute before or after
189   put() and delete() calls.
190 - The queue-name argument is now optional for async-session-persistence in
191   appengine-web.xml.
192 - Fixed a ClassNotFound error when using async-session-persistence.
193     http://code.google.com/p/googleappengine/issues/detail?id=5774
194 - Fixed an issue with memcache serialization when using a entity key with a name
195   that points to the same reference as the key's parent.
196     http://code.google.com/p/googleappengine/issues/detail?id=2088
197 - Fixed an issue where DoS stats in the Admin Console didn't work for High
198   Replication apps.
199     http://code.google.com/p/googleappengine/issues/detail?id=5237
200 - WARNING: Starting with 1.6.1 (our next release, NOT this release), URLFetch
201   requests will honor the Accept-Encoding header. If your code sets this header
202   then it must be prepared to receive content of the specified type. For more
203   information please see
204     http://code.google.com/p/googleappengine/issues/detail?id=4978
206 Version 1.5.5
207 =============
208 - We have increased the number of files you can upload with your application to
209   from 3,000 to 10,000.
210 - We have increased the size limit for a single file uploaded to App Engine from
211   10MB to 32MB.
212 - We have increased the Frontend request deadline from 30 seconds to 60 seconds.
213 - We have increased the online URLFetch maximum deadline from 10 seconds to 60
214   seconds. The default deadline remains at 10 seconds. The offline maximum deadline
215   for URLFetch remains at 10 minutes.
216 - We have increased the URLFetch Post payload from 1MB to 5MB.
217 - App Engine now supports Cross Group (XG) transactions with the High
218   Replication Datastore, which allow you to perform transactions across multiple
219   entity groups.
220     http://code.google.com/appengine/docs/java/datastore/transactions.html
221 - We have added a graph to the admin console that displays the number of
222   instances for which you will be billed.
223 - In the XMPP API, getPresence() is deprecated in favor of using the inbound
224   presence handlers documented in
225   http://code.google.com/appengine/docs/java/xmpp/overview.html#Handling_User_Presence.
226 - Fixed an issue in the Admin Console where the "Run Now" button did not work
227   for tasks with a '-' in the name.
228 - Fixed an issue to provide a better error message when a user tries to parse an
229   HttpRequest's input stream more than once in a request.
230 - Fixed an issue to provide a better error message when using the Mail API to
231   send email to an invalid user address.
232 - Fixed an issue in the SDK where HttpServletRequest.getInputStream().read()
233   always returned -1.
234     http://code.google.com/p/googleappengine/issues/detail?id=5396
235 - Fixed an issue where you could not schedule a cron job to run every 100
236   minutes.
237     http://code.google.com/p/googleappengine/issues/detail?id=5861
239 Version 1.5.4
240 =============
241 - You can now specify the maximum size for a blob in
242   BlobstoreService.createUploadUrl().
243 - Zigzag merge join queries will now continue scanning up to the 30 second
244   Datastore query deadline. For zigzag queries that used to generate
245   DatastoreNeedIndexException, many will now succeed. A small percentage will
246   now instead timeout.
247 - The SDK datastore viewer in the dev console now displays the number of "Write
248   Ops" for each entity. "Write Ops" are the total number of entity and index
249   writes that were required to create the entity.
250 - The Prospective Search API is available in Java for all applications. This API
251   is still experimental, so applications will be limited to a maximum of 1000
252   subscriptions.
253 - We made a classloading improvement that we expect to help loading request
254   latencies for projects with large numbers of jars.
255 - Added support for the set_default_version flag to Appcfg.
256 - The Java Remote API now recognizes the HTTP_X_APPENGINE_INBOUND_APPID. This
257   means that the Datastore Admin copy functionality will work when using
258   Java's Remote API with the destination app.
259 - Fixed an issue that incorrectly allowed creation of tasks with whitespace in
260   the url.
261 - Fixed the error message for "transaction not found" to be more descriptive.
262 - Fixed an issue with the dev appserver's local Blobstore implementation trying
263   to modify an immutable collection.
264     http://code.google.com/p/googleappengine/issues/detail?id=3081
265 - Fixed an SDK issue where CONFIG, FINE, FINER, FINEST logging messages were not
266   displayed.
267     http://code.google.com/p/googleappengine/issues/detail?id=4591
270 Version 1.5.3
271 =============
272 - We've removed the limit on the size of blob uploads using the Blobstore API.
273 - You can now send emails with any attachment extension that is not included on
274   the email attachment extension blacklist.
275 - Added a getIndexes() method to the DatastoreService to retrieve an
276   application's indexes and their corresponding states.
277 - The development server has been updated to understand the reduced index
278   requirements of the 1.5.2 datastore query planner changes.
279 - The Datastore Admin functionality can now be enabled directly in the Admin
280   Console.
281 - You can now use Remote API to access the services of one App Engine
282   application from a different App Engine application.
283 - The Java Testing APIs now default to UTC if no timezone is specified.
284 - AppCfg now supports download_app, which will download all files that were
285   uploaded from your war directory.
286 - AppCfg now supports the -V (version) and -A (application) flags.
287 - Added app_identity api with methods to work with service accounts for
288   asserting identity on outbound HTTP calls.
289     http://code.google.com/appengine/docs/java/appidentity/overview.html
290 - Added an improved HRD migration tool that requires a read-only period relative
291   to your datastore write rate (as opposed to your datastore size, which is how
292   the current version behaves). The tool is not yet generally available.  If you
293   are interested in being an early adopter please fill out this form:
294   http://goo.gl/3jrXu
295 - Fixed an issue in the Channel API where jsapi was not served with the correct
296   mime type.
297 - Fixed an issue where blobs could not be uploaded using HTTPS.
298 - Fixed an issue where GQL didn't allow querying for valid kind names
299   containing '.', '-', and ':' by supporting quoted identifiers.
300     http://code.google.com/p/googleappengine/issues/detail?id=2584
302 Version 1.5.2
303 =============
304 - You can now specify the minimum pending latency for instances and the maximum
305   number of idle instances for your application in the Admin Console.
306 - The datastore now never requires an exploding index.
307     http://code.google.com/appengine/docs/python/datastore/queries.html#Big_Entities_and_Exploding_Indexes
308 - The SDK will now never suggest indexes with the same property repeated, as
309   such indexes are likely to be exploding indexes.
310 - Datastore stats are now available on a per-namespace basis.
311 - The queue details page in the Admin Console now contains request header
312   details, previous run information, and a task payload viewer.
313 - You can modify the lease on a task leased from a pull queue using the
314   modifyTaskLease() method.
315 - Pull Task maximum size has been increased to 1MB.
316 - You can now update the number of available backend instances without needing
317   to first stop the backend using the "backend configure" appcfg directive.
318 - You can now set the "References" and "In-Reply-To" headers with the Mail API.
319     http://code.google.com/p/googleappengine/issues/detail?id=2802
320 - The whitelist has been updated to include support for JSR 105.
321 - When the SDK throws a DatastoreNeedIndexException for a missing index
322   definition, the exception can now be caught.
324 Version 1.5.1
325 =============
326 - The development server's datastore and testing service implementations now
327   contains logic that closely replicates the consistency guarantees of the High
328   Replication datastore. To use, run the dev_appserver with the flag
329   -Ddatastore.default_high_rep_job_policy_unapplied_job_pct=20.
330 - All user request have an X-AppEngine-Country header which contains the
331   ISO-3166-1 alpha-2 country code for the user, based on the IP address of the
332   client request.
333 - The Channel API can now provide user presence, this can be configured by
334   adding channel_presence to the list of inbound services for your application.
335 - The Images API now supports the WebP format.
336 - You can switch the timezone for App Engine logs in the Admin Console.
337   http://code.google.com/p/googleappengine/issues/detail?id=734
338 - Added javax.xml.ws.Service$Mode to the whitelist.
339   http://code.google.com/p/googleappengine/issues/detail?id=4770
340 - You can configure your application to asynchronously write https session data
341   by adding <async-session-persistence enabled="true"/> to your
342   appengine-web.xml.
343   http://code.google.com/p/googleappengine/issues/detail?id=1692
344 - The local task queue unit testing API now supports Deferred Tasks.
345 - Fixed an issue where using reserved URLs did not cause an error in the SDK.
346 - Fixed an issue where having a backends.xml configuration file caused logging
347   to stdout to fail in the SDK.
348 - Fixed an issue where the Channel API didn't work with non-default versions of
349   applications using the High Replication datastore.
350 - Fixed an issue where the Remote API rtok comparison was broken for some users,
351   causing appfcg download data to fail.
352 - Fixed an issue with the SDK where you could not apply a transform to PNG
353   images.
354   http://code.google.com/p/googleappengine/issues/detail?id=3458
355 - When displaying corrupt data in the Admin Console dataviewer, a useful error
356   will be displayed, instead of a 500.
357   http://code.google.com/p/googleappengine/issues/detail?id=4945
358 - Fixed an issue with the SDK where non-string index names caused an error upon
359   upload.
360   http://code.google.com/p/googleappengine/issues/detail?id=5004
361 - Datanucleus now supports polymorphic relationships.
362   http://code.google.com/p/datanucleus-appengine/issues/detail?id=153
363 - Datanucleus now supports PreparedQuery#countEntities(FetchOptions).
364   http://code.google.com/p/datanucleus-appengine/issues/detail?id=225
365 - Fixed an issue with datanucleus where recursive relation did not work.
366   http://code.google.com/p/datanucleus-appengine/issues/detail?id=80
368 Version 1.5.0.1
369 ===============
370 - Fixed a bug that caused appengine-jsr107cache-1.5.0.jar to be empty.
372 Version 1.5.0
373 =============
374 - Support for Backends which allow developers to create infrastructure
375   components that complement the existing dynamic apps that App Engine already
376   provides. Instances of a backend can maintain state, be addressed
377   individually, and are not subject to per-request time limits. They can also be
378   configured to consume more memory and CPU than ordinary dynamic instances.
379 - Task Queues support pull mode, allowing for more control over task queue work
380   rates. To use pull queues, include the 'mode' element in your queue.xml.
381 - Pull queues are supported by a REST API, allowing access from outside App
382   Engine. To use the REST API, you must also include a valid ACL section
383   specifying which users can lease tasks from the pull queue.
384 - Task Queue payload limits have been increased. Queues support 100KB per task.
385   Within App Engine, the new limit is 32 MB per batch of tasks. With the REST
386   API the limit is 1 MB per batch.
387 - HTTP request and response sizes have been increased to 32 MB.
388 - We have removed the rate quotas for requests, datastore operations,
389   memcache operations, and image API operations. Resource quotas still apply.
390 - When creating new applications, developers will now see the High Replication
391   Datastore as the default configuration option.  Developers that still wish to
392   use the Master/Slave configuration must explicitly choose this option at
393   application creation time.
394 - The Task Queue maximum configurable processing rate has been increased to
395   500/s.
396 - Modified Dashboard latency graphs to indicate they only include dynamic
397   requests.
398 - We have added two restrictions to the Mail API to improve the reliability
399   of the service for all applications.
400   - Emails must be sent from email accounts managed by Google (either Gmail or
401     a domain signed up for Google Apps).
402   - Reduced the number of free recipients per day from 2000 to 100 for new
403     applications.
404 - Fixed an issue where the Javadoc for the File API was not generated.
405 - Fixed an issue where the API Deadlines were not being enforced in the SDK.
406 - Fixed an issue with Federated Users causing the Admin Console dataviewer to
407   fail.
408     http://code.google.com/p/googleappengine/issues/detail?id=384
409 - Fixed an issue causing SDK URL Fetch not to work behind proxy.
410     http://code.google.com/p/googleappengine/issues/detail?id=544
411 - Fixed an issue deploying an app with version set to 0.
412     http://code.google.com/p/googleappengine/issues/detail?id=735
413 - Improved support for reserving an app id that is a canonicalized version of
414   a user's Gmail address.
415     http://code.google.com/p/googleappengine/issues/detail?id=1196
416 - Added a more useful error message for unavailable App Ids.
417     http://code.google.com/p/googleappengine/issues/detail?id=1303
418 - Added clearer error messaging for invalid transactions in the SDK.
419     http://code.google.com/p/googleappengine/issues/detail?id=1357
420 - Added better error messages for cron.xml parsing.
421     http://code.google.com/p/googleappengine/issues/detail?id=1490
422 - Entity constructors are now consistent with KeyFactory constructors.
423     http://code.google.com/p/googleappengine/issues/detail?id=1626
424 - Task Queue names can now include the "_" character.
425     http://code.google.com/p/googleappengine/issues/detail?id=1723
426 - The sender of an email is no longer BCC'd when they are already included in
427   the email.
428     http://code.google.com/p/googleappengine/issues/detail?id=1907
429 - Added a more helpful error message when trying to send email to a malformed
430   address.
431     http://code.google.com/p/googleappengine/issues/detail?id=2386
432 - The SDK now returns an error if the Content-length header is not included in a
433   post request, matching production.
434     http://code.google.com/p/googleappengine/issues/detail?id=2512
435 - Fixed an issue where the wrong type of error was being thrown on HTTP request
436   timeout.
437     http://code.google.com/p/googleappengine/issues/detail?id=2464
438 - Fixed an issue where the Admin Console didn't keep the app version viewed
439   consistent across actions.
440     http://code.google.com/p/googleappengine/issues/detail?id=4023
441 - Added Javadocs for TaskOptions.taskName().
442     http://code.google.com/p/googleappengine/issues/detail?id=4316
443 - Fixed a typo in the Admin Console on the New App page.
444     http://code.google.com/p/googleappengine/issues/detail?id=4620
445 - Fixed an issue where sending mail from an app registered on the HR datastore
446   required the app id be prefaced with s~.
447     http://code.google.com/p/googleappengine/issues/detail?id=4671
448 - Fixed an issue where HTTP POST was broken in the SDK if the Content-Length
449   header was specified.
450     http://code.google.com/p/googleappengine/issues/detail?id=4836
452 Version 1.4.3
453 =============
454 - Added FileService API that allows writing to and reading from files in
455   blobstore.
456 - You can now specify cron execution for a time interval between a start and end
457   time.
458 - You can now configure the specific application version to which a task queue
459   or cron job will send requests.
460 - The Admin Console Task Queues page now displays a more accurate estimate of
461   queue size for queues containing more than 2000 tasks.
462 - Java applications can enable concurrent request support by setting
463   <threadsafe> to True in their appengine-web.xml. This flag indicates that
464   request handlers for your app are thread safe and multiple request handlers
465   may safely run at the same time in the same memory space for your application.
466 - Deferred library support now available in Java.
467     http://code.google.com/p/googleappengine/issues/detail?id=2381
468 - Remote API library now available in Java. This can be used in conjunction with
469   apps using either the Java or the Python runtime.
470 - The Java SDK now supports kindless and ancestor only queries.
471 - Fixed an issue where JAX-WS clients in the SDK could not handle receiving a
472   SOAP fault.
473 - Fixed an issue where the SDK did not support fetching HTTPS URLs.
474 - Fixed an issue where no link was displayed in the Admin Console blobstore
475   viewer for an unnamed blob.
476 - Fixed an issue where the Admin Console data viewer couldn't edit entities
477   with ByteString properties.
478     http://code.google.com/p/googleappengine/issues/detail?id=2367
479 - Fixed an issue where the Admin Console crashed when using a non-ascii
480   key_name.
481     http://code.google.com/p/googleappengine/issues/detail?id=2451
482 - The Disable Application admin function has been button-ized.
483     http://code.google.com/p/googleappengine/issues/detail?id=4323
484 - Fixed a regex validation issue in the queue.xml file that caused some uploads
485   to break.
486     http://code.google.com/p/googleappengine/issues/detail?id=4365
487 - Fixed an issue where the Java SDK Task Queue did not support 10 minute
488   timeouts.
489     http://code.google.com/p/googleappengine/issues/detail?id=4564
490 - Fixed an issue where the Channel API in the SDK didn't properly send messages
491   with unicode characters.
492     http://code.google.com/p/googleappengine/issues/detail?id=4675
494 Version 1.4.2
495 =============
496 - You can now vacuum datastore indexes with the Java SDK.
497 - The XMPP API was updated to include presence and allow subscriptions.
498 - The Task Queue now supports programmatic deleting of tasks.
499     http://code.google.com/p/googleappengine/issues/detail?id=2588
500 - The maximum rate per queue at which tasks are processed has been increased to
501   100 task per second.
502 - The maximum number of concurrent requests for a single queue can be specified
503   in the application's queue.xml. This provides an additional easy-to-use form
504   of rate limiting. The current number of running tasks is also displayed in
505   the Admin Console.
506 - Metadata queries in the Datastore now support cursors.
507 - Admin Console logs viewer now displays time as YYYY-MM-DD HH:MM:SS.mmm.
508 - The Mail API added KML and KMZ files as allowed attachments.
509 - Added support for verifying the server SSL certificate when making a
510   URLFetch request to an HTTPS URL. This will become the default in a future
511   release.
512 - Added a warning when an admin tries to upload a queue.yaml where the number
513   of new queues and the number of disabled queues exceeds 100.
514 - Added a putIfUntouched() method to the Memcache API.
515     http://code.google.com/p/googleappengine/issues/detail?id=2139
516 - Added JAX-WS support for writing SOAP clients and SAAJ support for writing
517   SOAP servers. JAX-WS for SOAP servers is not yet supported.
518 - Fixed an issue where mail from @appid.appspotmail.com did not work when
519   sending mail to app admins.
520 - Fixed an issue where the SDK did not enforce the 100 task limit for the Task
521   Queue.
522     http://code.google.com/p/googleappengine/issues/detail?id=3296
523 - Fixed an issue where the Java SDK URLFetch did not support 32MB response
524   sizes.
525     http://code.google.com/p/googleappengine/issues/detail?id=4215
526 - Fixed an issues where <jsp-file> mappings in web.xml were broken.
527     http://code.google.com/p/googleappengine/issues/detail?id=4216
529 Version 1.4.1
530 =============
531 There were no updates to the Java SDK for the 1.4.1 App Engine release.
533 Version 1.4.0
534 =============
535 - The Always On feature allows applications to pay and keep 3 instances of their
536   application always running, which can significantly reduce application
537   latency.
538 - Developers can now enable Warmup Requests. By specifying  a handler in an
539   app's appengine-web.xml, App Engine will attempt to send a Warmup Request to
540   initialize new instances before a user interacts with it. This can reduce the
541   latency an end-user sees for initializing your application.
542 - The Channel API is now available for all users.
543 - Task Queue has been officially released, and is no longer an experimental
544   feature. The API import paths that use 'labs' have been deprecated. Task queue
545   storage will count towards an application's overall storage quota, and will
546   thus be charged for.
547 - The deadline for Task Queue and Cron requests has been raised to 10 minutes.
548   Datastore and API deadlines within those requests remain unchanged.
549 - For the Task Queue, developers can specify task retry-parameters in their
550   queue.xml.
551 - Apps that have enabled billing are allowed up to 100 queues with the Task
552   Queue API.
553 - Metadata Queries on the datastore for datastore kinds, namespaces, and entity
554   properties are available.
555 - URL Fetch allowed response size has been increased, up to 32 MB. Request size
556   is still limited to 1 MB.
557 - The request and response sizes for the Images API have been increased to
558   32 MB.
559 - The total size of Memcache batch operations is increased to 32 MB. The 1 MB
560   limit on individual Memcache objects still applies.
561 - The attachment size for outgoing emails has been increased from 1 MB to 10 MB.
562   The size limit for incoming emails is still 10 MB.
563 - Size and quantity limits on datastore batch get/put/delete operations have
564   been removed. Individual entities are still limited to 1 MB, but your app may
565   batch as many entities together for get/put/delete calls as the overall
566   datastore deadline will allow for.
567 - When iterating over query results, the datastore will now asynchronously
568   prefetch results, reducing latency in many cases by 10-15%.
569 - The Admin Console Blacklist page lists the top blacklist rejected visitors.
570 - The automatic image thumbnailing service supports arbitrary crop sizes up to
571   1600px.
572 - Overall average instance latency in the Admin Console is now a weighted
573   average over QPS per instance.
574 - Added a low-level AysncDatastoreService for making calls to the datastore
575   asynchronously.
576 - Added a getBodyAsBytes() method to QueueStateInfo.TaskStateInfo, this returns
577   the body of the task state as a pure byte-string.
578 - The whitelist has been updated to include all classes from javax.xml.soap.
579 - Fixed an issue sending email to multiple recipients.
580     http://code.google.com/p/googleappengine/issues/detail?id=1623
581 - Revert the default logging level during GWT hosted mode back to INFO.
582     http://code.google.com/p/googleappengine/issues/detail?id=4011
583 - Fixed an issue with OpenId over SSL.
584   http://code.google.com/p/googleappengine/issues/detail?id=3393
586 Version 1.3.8
587 =============
588 - You can run task queue tasks immediately from the admin console.
589 - Added an OutputSettings class to the Images API to specify the JPEG encoding
590   quality when running in production.
591 - Support for login of multiple Google accounts within an app, and longer login
592   sessions. For more information see:
593     http://www.google.com/support/accounts/bin/answer.py?answer=181599
594 - In queue.xml, the maximum allowed bucket size is now 100.
595 - Removed limits on zigzag merge-join queries. Therefore the error "The built-in
596   indices are not efficient enough for this query and your data. Please add a
597   composite index for this query." will no longer be thrown in most cases,
598   enabling more types of queries without indexes.
599 - The whitelist has been updated to include java.net.InetAddress and some
600   interfaces and abstract classes in javax.xml.soap, including
601   javax.xml.soap.SOAPMessage.
602 - Fixed an issue reserving App Ids by owners of emails containing periods,
603   multiple cases, and googlemail.com address.
604     http://code.google.com/p/googleappengine/issues/detail?id=1196
605 - Fixed an issue where TaskOptions had no public getters, making testing
606   impossible.
607     http://code.google.com/p/googleappengine/issues/detail?id=3243
608 - Fixed an issue on the development server where PNGs were being returned as
609   JPEGs.
610     http://code.google.com/p/googleappengine/issues/detail?id=3661
612 Version 1.3.7
613 =============
614 - Fixed an SDK issue where calling getServingUrl raised an exception.
615     http://code.google.com/p/googleappengine/issues/detail?id=3598
617 Version 1.3.6
618 =============
619 - Multitenancy is now supported in the datastore, allowing better
620   compartmentalization of user data.
621 - Automatic image thumbnailing is now available in the Images API using
622   getServingUrl.
623 - Users can now serve custom static error pages for over_quota, dos_api_denial
624   and default cases.
625 - Results of datastore count() queries and offsets for all datastore queries
626   are no longer capped at 1000.
627 - Added a pause queue button to the task queue details page in the Admin
628   Console.
629 - Historical graphs have been added to all of the dashboard graphs in the Admin
630   Console.
631 - Content-range headers are supported on Blobstore downloads.
632 - New method to allocate datastore ids in a given range: allocateIdRange()
633 - The app.yaml format is supported with Java applications.
634 - Increased several rate limited quotas for free applications.
635 - Fixed an issue that did not allow forms of over 200,000 bytes to be submitted.
636    http://code.google.com/p/googleappengine/issues/detail?id=1608
638 Version 1.3.5
639 =============
640 - Ability to configure the Task Queue storage limit with the
641   total-storage-limit field in the queue.xml file.
642 - Task Queues now support up to 50 qps per queue, up from 50 qps per app.
643 - Developers can programmatically access Blobs with BlobstoreInputStream, which
644   provides an InputStream view of a blob in Blobstore
645 - Bulkloader transform helpers for lists and hierarchical keys were added.
646 - remote_api_shell commands can be sent over HTTPS or HTTP.
647 - Admin Console logs now include information on request time latency.
648 - The datastore now supports end cursors.
649 - Fixed an issue where requesting /appstats would not properly direct to
650   /appstats/.
651 - Fixed an issue with inconsistent URL mappings between the SDK and production.
652     http://code.google.com/p/googleappengine/issues/detail?id=2598
654 Version 1.3.4
655 =============
656 - Client side bulkloader available with the Python SDK that has a new
657   configuration syntax and wizard for easier import/export with the datastore.
658   Can be used by enabling remote_api in your Java application
659 - Applications can now be configured to authenticate with OpenID by selecting
660   the OpenID option when creating your application in the admin console
661     http://code.google.com/p/googleappengine/issues/detail?id=248
662     http://code.google.com/p/googleappengine/issues/detail?id=56
663 - New API to allow App Engine apps to act as OAuth service providers
664     http://code.google.com/p/googleappengine/issues/detail?id=919
665 - The version update check in the Java SDK now uses https
666 - Allow full access to javax.el.*
667     http://code.google.com/p/googleappengine/issues/detail?id=3157
668 - Increased the timeout during deployment to 15 minutes
669 - Fixed an issue with JPA where an illegal cast exception was thrown during the
670   fetch of integer fields
671 - MemcacheService.setNamespace() is deprecated in favor of
672   MemcacheServiceFactory.getMemcacheManager(namespace)
673 - Support in the SDK for Java 1.5 is being deprecated. These warnings now appear
674   when starting the SDK
676 Version 1.3.3.1
677 ===============
678 - Fixed an issue where servlet filters could cause 404s
679     http://code.google.com/p/googleappengine/issues/detail?id=3138
681 Version 1.3.3
682 =============
683 - Added two new system properties com.google.appengine.application.id and
684   com.google.appengine.application.version
685 - DeadlineExceededException is now always thrown before
686   HardDeadlineExceededError
687 - Decreased likelihood of "Too many URLMap" deployment errors for complex
688   web apps
689 - Fixed an error where QuotaService.getCpuTimeInMegaCycles() was returning
690   cycles instead of megacycles
691 - Fixed an issue between differing behavior of jsp in the production and
692   development environments
693     http://code.google.com/p/googleappengine/issues/detail?id=3022
694 - Fixed an issue uploading webapps with .tag files
695     http://code.google.com/p/googleappengine/issues/detail?id=2902
697 Version 1.3.2
698 =============
699 - New API to read the contents of uploaded Blobs (fetch_data)
700     http://code.google.com/p/googleappengine/issues/detail?id=2536
701 - URLFetch now supports accessing ports 80-90, 440-450, and 1024-65535
702 - Mail API now allows common document formats as attachments
703     http://code.google.com/p/googleappengine/issues/detail?id=494
704 - The Task Queue API now supports adding multiple tasks in a single call to
705   Queue.add()
706 - Fixed charset handling for inbound emails
707     http://code.google.com/p/googleappengine/issues/detail?id=2326
708 - Fixed issue with compositing background colors in dev_appserver
709 - New feature in the datastore to specify whether to use strong or eventually
710   consistent reads (the default is strong)
711 - New datastore feature allows setting deadlines for operations
712 - Increased the maximum Task Queue refill rate from 20/s to 50/s
713 - Support for IP blacklisting to prevent denial of service (DoS) attacks
714 - App Stats is now available for the Java SDK in addition to Python
715 - Fix issue with expiration times not being reset on Put on the Memchache API
716     http://code.google.com/p/googleappengine/issues/detail?id=1284
717 - Fix issue preventing static files from being served when a servlet is mapped to root
718     http://code.google.com/p/googleappengine/issues/detail?id=1379
720 Version 1.3.1
721 =============
722   - Datastore Query Cursors
723       http://code.google.com/appengine/docs/java/datastore/queriesandindexes.html#Query_Cursors
724   - Transactional Tasks
725   - Support for Custom Admin Console pages
726   - Java Precompilation is now on by default
727       Developers can opt-out of precompilation by setting the flag in
728       appengine-web.xml:
729       <precompilation-enabled>false</precompilation-enabled>
730   - New built-in support for unit testing (see appengine-testing.jar)
731       http://code.google.com/appengine/docs/java/tools/localunittesting.html
732       http://code.google.com/p/googleappengine/issues/detail?id=326
733   - net.sf.jsr107 package included as an alternative to the low-level
734     Memcache API
735   - javax.annotation.Resource/Resources added to the package whitelist
736   - New "month" and "synchronized" syntax for Cron configuration
737       http://code.google.com/appengine/docs/java/config/cron.html
738   - URLFetch supports asynchronous requests
739       http://code.google.com/p/googleappengine/issues/detail?id=1899
740   - appcfg.sh uses HTTPS for application deployment
741   - appcfg.sh adds request_logs --append
742   - Changes to the order queries without a specified sort order are returned
743     Only queries that use IN will see different results.
744   - Added support for multiple != filters on the same property
745   - Improved support for keys-only queries when using IN and != filters
746   - Support for ETags, If-matches, If-not-matches HTTP Headers, as well as 304
747     status codes now available on static files (not yet available on the
748     dev_appserver or Blobstore blobs)
749       http://code.google.com/p/googleappengine/issues/detail?id=575
750   - Fixed issue where the maximum transform count was enforced for composite
751     operations
752       http://code.google.com/p/googleappengine/issues/detail?id=1656
753   - Fixed issue with whitespace on the end of strings in web.xml
754       http://code.google.com/p/googleappengine/issues/detail?id=2242
755   - Fixed web.xml <error-page> entries for 404 error codes
756       http://code.google.com/p/googleappengine/issues/detail?id=1477
757   - Added validation prevent welcome-files with absolute paths
758       http://code.google.com/p/googleappengine/issues/detail?id=1249
759   - Fixed issue where cancelling a deployment in progress could unintentionally
760     corrupt the SDK
761       http://code.google.com/p/googleappengine/issues/detail?id=2255
762   - Fixed issue with QuotaService.getCpuTimeInMegaCycles() returning 0
763       http://code.google.com/p/googleappengine/issues/detail?id=2639
764   - Fixed issue where JSP exceptions will be incorrectly cast causing a
765     ClassCastException
766       http://code.google.com/p/googleappengine/issues/detail?id=1438
768 Version 1.3.0
769 =============
770   - Support for the new Blobstore API
771   - New com.google.appengine.runtime.{version,environment} system properties
772     (and a SystemProperty accessor class)
773   - New sample applications for GWT 2.0
774   - Optimizations for many reflection operations
776 Version 1.2.8
777 =============
778   - Support for JAXB. JAXB is included in JDK 1.6 (and App Engine's production
779     servers). If you're using JDK 1.5 with your local dev_appserver, you will
780     need to include the JAXB libraries with your application to use it.
781       http://code.google.com/p/googleappengine/issues/detail?id=1267
782   - New support for application pre-compilation to reduce the length of
783     loading requests. To enable pre-compilation on your application, add this
784     flag to your appengine-web.xml:
785       <precompilation-enabled>true</precompilation-enabled>
786     If you have trouble deploying your application, you should remove this
787     flag or set it to false.
788   - Added Quota API (com.google.appengine.api.quota) to match Python API.
789   - Low-level Memcache API now supports batchIncrement().
790   - HTTPResponse object now has getFinalUrl() method for 302 redirects.
791     - http://code.google.com/p/googleappengine/issues/detail?id=1464
792   - Java Dev Appserver now automatically executes tasks.  If you prefer the
793     old behavior where tasks do not automatically execute you can use the
794     following flag when starting the server:
795       -Dtask_queue.disable_auto_task_execution
796   - Additional file extensions permitted when sending mail.
797     - http://code.google.com/p/googleappengine/issues/detail?id=494
798   - Fixed issue with Java mail handler not processing multipart messages
799     correctly.
800   - Fixed agent code included in appengine-local-runtime.jar results in
801     RuntimeException.
802     - http://code.google.com/p/googleappengine/issues/detail?id=2280
803   - Fixed issue with sort orders defined on properties that allow multiple
804     values.
805     - http://code.google.com/p/googleappengine/issues/detail?id=2349
806   - Fixed problem with dropped query strings after requiring log-in.
807     - http://code.google.com/p/googleappengine/issues/detail?id=2225
808   - Removed limitation preventing multiple parameters with the same name.
809     - http://code.google.com/p/googleappengine/issues/detail?id=2090
810   - Fixed issue with local datastore incorrectly sorting results of ancestor
811     queries.
812     - http://code.google.com/p/googleappengine/issues/detail?id=2177
813   - New Index building status page in the Admin Console
814   - Task Queue now supports purging queues, and deleting tasks and queues via
815     the Admin Console.
816     - http://code.google.com/p/googleappengine/issues/detail?id=2159
817     - http://code.google.com/p/googleappengine/issues/detail?id=1740
818   - Over Quota HTTP status code changed from 403 to 503, other to 500.
819     - http://code.google.com/p/googleappengine/issues/detail?id=961
820   - Task Queue now considers all HTTP 2xx status codes to represent success.
822 For past release notes, visit:
823 http://code.google.com/p/googleappengine/wiki/SdkForJavaReleaseNotes